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(57) Abstract: A system for wireless remote control (30) of a gateway (10) and ordering or invocation of services provided by a 
headend (12). The remote control includes a video display (60) and user input device or keyboard (54) and can decompress and dis- 
play compressed streaming video in some embodiments. Some species of the remote control (30) can act as web browsers, appliance 
control, TIVO function control, an IP telephony telephone, a cellular telephone and/or and MP3 player (163). In some embodiments, 
the gateway (10) and/or headend (12) can implement TlVO-like functions under control from a wireless remote of custom design or 
implemented on a Personal Digital Assistant. 
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Background of the Invention 

This application discloses gateways and settop decoders for use in home networks as 
well as the home network Itself and an intelligent remote control. 
5 The introduction of cable modems and broadband services to cable television systems 

has given rise to the development of home gateway systems. These systems couple the digital 
and analog cable television hybrid fiber coax cables to telephones, computers, FAX machines, 
settop box TV adapters, digital VCRs, cameras etc. for bidirectional digital communication 
with the headend and receiving conventional analog downstream broadcasts. These systems 
1 0 can implement video on demand, broadband internet access, monitoring at the headed of 
security camera video taken in customer homes, interactive games resident on a server at 
the headend and a host of other applications. 

Personal digital assistants and handheld computers (hereafter PDAs) that can display 
video exist. However, to the applicant's knowledge, no PDA has the application software and 

1 5 communication circuitry and drivers needed to communicate with ai gateway and act as a 

remote control to control analog and digital equipment at a customer premises. Further, no 
PDA exists which can act as a remote control to control headend processing relevant to the 
customer premises where the remote is located such as ordering video-on-demand 
selections, responding to queries, sending and receiving e-mail through a mail server at the 

2 0 headend, browsing the internet by sending URL and other commands to a web server at the 

headend and displaying the retrieved web pages, interacting with game servers at the 
headend, etc. 

Further, no remote control that is not a modified PDA exists with a display that can 
display television or other images. In particular, no remote control, whether based on a 

2 5 PDA or not, exists that can by issuing commands through a cable modem and gateway at a 

customer premises, monitor one video channel while watching another. 

With the advent of digital broadcast television systems such as DirecTV and Dish 
Network and cable TV and ADSL systems delivering digital data, a need for gateway circuits 
that can interface these different mediums to various peripherals that use the data has 

3 0 arisen. The UitimateTV personal digital data "pseudo video tape recorder" is one limited 

type of gateway that has recently become commercially available to interface a satellite dish 
and a telephone line to a wireless remote control and a television. The applicants do not 
admit the UitimateTV gateway is prior art since the applicant's invention of the same concept 
dates back at least to the summer of 2000. The UitimateTV gateway however does not have 
3 5 the ability to also interface an HFC or DSL network to peripherals either directly connected 
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to the gateway through USB or Firewire or SCSI buses or indirectly connected through one or 
more local area networks. 

The introduction of the TIVO personal digital video recorder has created a whole new 
market. However the TIVO has several disadvantages. The TIVO uses infrared commands to 
5 an infrared transducer affixed to an external digital video broadcast receiver to change the 
channels thereof in response to channel selection commands entered by a TIVO remote 
control. The satellite receiver is external to the TIVO system, and has its own remote 
control. The TIVO prior art system gets confused and often records no signal at all when an 
uninitiated family member such as a child changes the channel on the separate digital TV 
1 0 satellite receiver using that receiver's remote control instead of the TIVO controller. This 
confuses the TIVO prior art system because, if the channel is changed without using the TIVO 
controller, the TIVO system does not know to which channel the dish receiver is currently 
tuned. Strangely, the TIVO prior art system tunes an external digital video satellite receiver 
by sending it infrared "differential" commands. Thus, if the TIVO knows the receiver is 

1 5 tuned to channel 100 and the TIVO wants to record a program on channel 125, the TIVO will 

issue a command to increase the channel number by 25 either by giving 25 channel up 
commands or by giving a command to increase the channel number by 25 Instead of simply 
giving a command "change to channel 125". This is a serious drawback if small children or 
TlVO-challenged people are using the TV. Further, because the satellite receiver is external 

2 0 to the TIVO, it must be kept on at all times because the TIVO cannot turn it on and off when 

needed to record programs. In energy starved states like California, this is a problem. 

Recently, the UltimateTV personal digital video recorder was introduced by Microsoft 
that solves the "on all the time" and channel confusion problems of TIVO. This unit may not 
be prior art to the gateway and headend cherrypicker that implement TIVO functions 

2 5 inventions disclosed herein because of an earlier conception date. Further, having the TIVO 

functions done in a gateway or a headend is different than having then done in a separate 
digital video recorder, and it saves customers money by only needing to pay for the service 
and not buy an entire TIVO unit and subscription to the program data, 

A need has therefore arisen for a wireless remote control which can, through a cable 

3 0 modem and gateway and settop box, issue commands to a headend to allow the remote to 

monitor one video channel while watching another on a TV. There is also a need for an 
intelligent remote that can change video channel selections for the TV or remote by issuing 
commands to the headend. There is also a need for an intelligent remote control that can 
issue commands to a headend to order video-on-demand programs. There is also a need for a 
3 5 wireless remote that can issue commands to a headend to browse the internet through a 
headend web server and display text and graphics or web pages or e-mail on the remote 
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display or on a television coupled to a gateway in communication witli the remote. There is 
also a need for an intelligent remote that can issue commands to a gateway or headend to 
control the gateway or headend to carry out TlVO-like functions for the customer. There is 
also a need for a gateway that can implement TIVO like functions as well as interface 
5 peripherals to various types of broadband digital data delivery transmission mediums and 
headend circuitry providing digital data delivery services. There is also a need for a headend 
cherrypicker that can be controlled by a wireless remote control which can implement TIVO 
like recording functions. 
Summary of the Invention 
1 0 The genus of the invention is defined by a group of species comprised of systems that 

can work with an intelligent remote control to control services provided to a customer 
through headend servers and other equipment in a bidirectional digital data delivery system 
implemented over some transmission medium. In this class of systems, the transmission 
medium may be a CATV HFC network or any other bidirectional digital data communication 

1 5 medium between a gateway at the customer premises and a headend. Other mediums the 

systems of the invention may be built around are DSL lines or bidirectional digital satellite 
services. 

A subgenus within the genus of the invention is a class of intelligent remote controls 
with a display which can issue commands to the headend in a bidirectional digital data 

2 0 communication system to do one or more of the following functions: 

(1) monitor one video channel while watching another on a TV; 

(2) change video channel selections for the TV or remote; 

(3) order video-on-demand programs; 

(4) browse the internet through a headend web server and display text and graphics of web 

2 5 pages or e-mail on the remote display; 

(5) control local peripherals coupled to a customer premises gateway either directly by RF 
or infrared link to the peripheral or through commands issued to the gateway from the 
remote via a settop box with suitable RF or infrared transceiver circuitry; 

(6) carry out TlVO-like functions for the customer; and/or 

3 0 (7) and control any other servers or other circuitry at the headend to enjoy services 

provided to the customer from the headend. 

In addition, in some embodiments within the intelligent remote control genus, a PDA 
serves as the platform on which the intelligent remote control application runs and 
additional software applications can be added to the PDA for calendar, contacts or phone book, 
3 5 etc. In addition, the PDA may have a PCMCIA port into which PC cards to provide expansion 
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memory and/or other expansion functions such as wireless modems for wireless e-mail and 
investing functions, cellular phone calls, etc. 



Brief Description of the Drawings 

5 Figure 1 is a block diagram of generic species of system using an intelligent remote 

control that can exercise and control services provided by headend equipement to a customer 
premises in which the remote is used. 

The broadest concept of the Invention is illustrated in Figure 2 which teaches a 
remote control without a display that can Issue wireless commands to a headend to invoke 
1 0 services provided thereby through one or more servers that provide the requested service. 

Figure 3 discloses limited use customer premises system utilizing a wireless remote 
control that controls a specialized TlVO-like gateway that interfaces a television to a 
satellite dish to receive digitized video broadcasts or video-on-demand data from a digital 
video headend elsewhere and interfaces the television and wireless keyboard remote to the 

1 5 public service telephone network for bidirectional IP packet data transfers to and from the 

internet via an internet server at the central office. 

Figure 4 is a block diagram of a system that uses a satellite link for unidirectional 
downstream digital video transmissions and uses a gateway coupled to a hybrid fiber coaxial 
network of a cable television system for provision of bidirectional high speed internet access 

2 0 and other broadband services. 

Figure 5 is a block diagram of one embodiment for a gateway 1 0 in Figures 1 and 4 
which have the ability to implement TiVO functions as well as interface the peripherals 
coupled to the gateway to two different broadband digital data delivery systems, specifically, 
digital video data broadcast systems and high bandwidth digital data services delivered over 

2 5 and HFC cable plant. 

Figure 6 is a block diagram of a more generalized architecuture for a cable headend, 
central office or satellite uplink facility to deliver iData and VOD and/or broadcast video data 
to customers via HFC, DSL or satellite and which can perform TIVO functions for each 
customer using disk storage at the headend. 

3 0 Figure 7 is a block diagram of a more generalized architecuture for a cable headend, 

central office or satellite uplink facility, represented by cloud 292. 

Figure 8 is a block diagram of an advanced home gateway with built in TIVO video 
server, multiple broadband Interface capability, multiple LAN Interface capability and built 
in email, web server, answering machine, voicemail and PBX functionality. 
3 5 Figure 9 is a block diagram of a wireless remote control Implemented on a personal 

digital assistant (PDA) having wireless capabilities. The remote control of Figure 9 can do 
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all regular PDA functions It is programmed to do such as calendar and appointments, word 
processing, database and address book functions. However, in addition, it has a wireless RF 
transceiver module 380 that plugs into the PDA's PCMCIA or Handspring Visor Springboard 
slot by which commands and data can be exchanged with the transceiver of a home gateway or 
5 some settop decoder with a transceiver on a LAN coupled to the gateway. 

Detailed Description of the Preferred and Alternative Embodiments 

Figure 1 is a block diagram of generic species of system using an intelligent remote 
control that can exercise and control services provided by headend equipment to a customer 
1 0 premises in which the remote is used. The invention contemplates a genus of systems all 
species of which share the following common characteristics: all species Include a remote 
control with display which is capable of sending commands to the headend through a gateway 
at the customer premises to exercise and control customer services provided by a headend. 
Such systems include the following components. 

1 5 First, there must be an individual, wireless remote control 30. 

Second, there must be a suitable home gateway 1 0 that includes a router with 
multiple ports for coupling to multiple LANs or directly to multiple peripherals or via 
multiple individual LAN segments, each coupled to a peripheral. The gateway must be one 
which can interface to the remote control, the one or more local area networks coupled to the 

2 0 peripherals to be serviced from the headend and one or more of the types of high bandwidth 

transmission medium 14. The broadband transmission medium 14 can be satellite, hybrid 
fiber coaxial cable, XDSL or wireless local loop or some combination of these different types 
of mediums. The gateway must be able to do the appropriate routing and any needed protocol 
conversions to get the data transmitted over whatever data path the router sets up. 

2 5 There will also be one or more local area networks 28 and/or individual LAN 

segments acting as dedicated lines from gateway 10 to each peripheral. The LAN(s) or 
individual LAN segments/dedicated lines couple the gateway's router to peripherals that 
exercise or utilize the customer services provided by the headend. Typically, there is one 
fast LAN and one slower LAN, but any type of physical medium in any configuration and any 

3 0 protocol including wireless LAN technology and LANs that use the power lines, phone lines, 

existing CATV coax, or custom installed wires may be used. Each port of the router can be 
coupled to a LAN which can be expanded by addition of repeaters, bridges or switches. The 
choice of LAN technology should be made based upon the anticipated traffic load since 
streaming video is a high bandwidth proposition even when compressed. The LAN 
3 5 configuration should also be established so that the various peripherals coupled to the router 
in the gateway can talk to each other over the LAN or LANs or individual LAN segments or 
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dedicated lines. Gateway 21 at customer premises #2 illustrates a gateway with a router 23 
with multiple ports coupled to a first LAN configuration 25 and individual LAN segments 27, 
29 and 31 coupled to peripherals. Gateway 21 also has a third LAN implemented on the 
existing CATV coaxial cable wiring In the home. Coax segment 35 couples the router 23 to a 
5 splitter 37. The splitter is coupled to a plurality of peripherals 39, 41, 43 via individual 
coaxial cable segments 45, 47 and 49. The individual peripherals can tall< to each other 
through the router 23 or via the leakage path between splitter ports. This use of existing 
CATV wiring as a LAN is covered in the claims one one incarnation of the limitation "local 
are network". In some embodiments using existing CATV wiring as the LAN, frequency 
1 0 division multiplexing Is used wherein existing analog CATV broadcasts are transmitted on the 
coax in one frequency band and digital data is communicated over the coaxial cable acting as a 
LAN on one or more RF carriers in a different band that does not interfere with the CATV 
analog signal carriers. Gateway 21 also has a rate shaping circuit 33. 

There will also be one or more suitable type headend(s) 12 that can interface to the 

1 5 one or more broadband transmission medium(s) 14 in use and which includes or is coupled 

to one or more servers or other circuits which provide the customer services to the 
peripherals. The headend(s) are controlled by the remote controls at the customer 
premises. 

Signals to be transmitted over shared hybrid fiber coaxial cable networks or local 

2 0 area networks at the customer premises to decoding circuits or other destination circuits 

may consume more bandwidth than is available. This is because the total available bandwidth 
on HFC is shared between all customers on the same network, so In times of high demand, not 
every customer gets all the bandwidth needed. However, video is a very high bandwidth 
application, so conflicts between bandwidth needed and bandwidth available can arise in HFC. 

2 5 Likewise, bandwidth on DSL lines is limited also, but it is not limited from sharing. It is 

limited from the limitations of twisted pair transmission mediums. Likewise, satellite 
uplinks and downlinks are shared among large numbers of customers, so bandwidth 
availability is an issue. There exists in the prior art bandwidth modification circuitry 
which can alter the consumed bandwidth so as to fit the available bandwidth of the channel or 

3 0 medium on which data is to be transmitted. Bandwidth alteration processing can be 

accomplished in commercially availabe integrated circuits designed by Imedia and available 
from the assignee of the present Invention. 

To help avoid bottlenecks and congestion on transmission medium 1 4, headend 1 2 
may include optional rate shaping circuitry, symbolized by dashed box 1 5, to adjust the data 
3 5 rate of data transmitted to the gateways 10 or received from the gateways to help alleviate 
bottlenecks on transmission medium 14. In some embodiments, all of the gateways and 

6 
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cherrypickers disclosed in the various embodiments disclosed herein include, where 
necessary, rate shaping circuitry or bandwidth modifiers to programmably alter the data 
rate and bandwidth consumed by various data transmissions. In other embodiments, there 
will be rate shaping circuitry only in the gateways or only in the headend. In other 
5 embodiments where the bandwidth of transmission medium 14 is large such as In fiber-to- 
the-curb systems, rate shaping circuitry may possibly be omitted altogether. The rate 
shaping circuitry is managed to give the best quality of video for the available bandwidth. 
All the gateways and cherrypickers disclosed herein also, where necessary, include 
circuitry to manage overflow or underflow of buffers in the circuits to which data is being 
1 0 transmitted over the LAN or hybrid fiber coaxial cable network. 

Gateway 1 0, in some embodiments, incorporates a hard disk to record digital video 
data or other data received via the medium or mediums 14 by which the gateway Is coupled to 
one or more headend servers. Further, gateway 10, in some embodiments, contains suitable 
interface circuitry to interface to more than one type of transmission medium coupling It to 

1 5 headend servers. For example, medium 14 may include a satellite dish and/or an HFC 

network and/or a DSL line and/or a conventional terrestlal television antenna. Therefore, 
in various embodiments, gateway 10 may include: circuitry that implements the functions of 
a digital broadcast television receiver such as a DirecTV or Dish network receiver; a cable 
modem or DOCSIS cable modem; and/or a DSL modem; a LAN interface, a personal video 

2 0 recording hard disk and control circuitry to implement T! VO functions and rate shaping 

circuitry 11 to change the data rate of data transmitted to or received from headend 12 over 
transmission medium 14. Rate shaping circuitry 11 also functions to rate shape (alter the 
data rate and bandwidth consumed) video data received from the headend 12 or from the hard 
disk of a TIVO system embedded in gateway 10 to alter the data rate to match the 

2 5 transmission capabilities of LAN 28. The structure and operation of rate shaping circuitry 

is well known and chips to do it have been designed by Imedia, Inc., formerly of San 
Francisco, California, and are now in public use by the assignee of the present invention. 
Rate shaping circuitry, circuitry to transmit variable bit rate compressed video data and 
auxiliary data at a constant bit rate, circuitry to minimize data rate fluctuations in forming 

3 0 multiplexes of multiple MPEG video streams, circuitry to provide video-on-demand to 

multiple subscribers simultaneously, circuitry to multiplex multiple l\/IPEG encoded video 
channels onto one data channel more efficiently, circuitry to playback compressed video is 
described in U.S. patents 5,956,088 and 5,877,812 and 5,966,120 and 5,926,205 and 
5,949,948 and 5,862,140, all of which are hereby incorporated by reference. This 
3 5 circuitry may be employed In the gateway and/or headend circuitry as necessary depending 
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upon the choices for the LAN technologies at the customer premises and/or the high 
bandwidth transmission medium(s) 14. 

Likewise, gateway 10 can include a conventional modem, represented by block 13, to 
interface the gateway to the public service telephone network (hereafter PSTN) to do such 
5 functions as downloading program guide data to implement TIVO functions in gateway 10. 

The particular embodiment of Figure 1 implements the system invention and the 
remote control invention, but the particular home gateway can be any existing gateway. 
Home gateways that can be used as gateway 10 are disclosed in a U.S. patent application 
serial number 09/483,681, filed 1/14/00, entitled HOME NETWORK FOR ORDERING AND 
1 0 DELIVERY OF VIDEO ON DEMAND, TELEPHONE AND OTHER DIGITAL SERVICES, which is 
hereby incorporated by reference. This patent application discloses conventional ADSL 
gateways, conventional HFC gateways and a unique gateway that interfaces a plurality of 
different types of computing devices and television type equipment to hybrid fiber coaxial 
(HFC) cable broadband services, satellite dishes or terrestial broadcast antennas. 

1 5 Gateway 1 0 has an RF or infrared transceiver 32 therein to send and receive data 

to/from remote 30 in customer premises #1. The gateway 10 also has an internal router 
and tuner and demodulation and detector circuitry suitable for the type of digital data 
transmissions from the headend that are being received. When the remote 30 issues 
commands to request services from the headend, the resulting digital data transmitted by the 

2 0 headend 12 to gateway 10 arrives on a particular logical channel. A logical channel will be a 

particular frequency RF carrier and a particular multiplexed logical channel thereon such 
as a particular timeslot or one or more particular spreading codes. The data on this 
particular logical channel will be transmitted for use on a particular peripheral coupled to 
LAN 28. For example, the remote control 30 might be used to order a particular video-on- 

2 5 demand movie to be displayed on television 34. This command will be received by gateway 

10 and transferred to headend 12. The headend sends a suitable command to the video-on- 
demand servers 18 requesting the data of the requested movie. The data is provided and is 
transmitted by the headend on a particular logical channel on transmission medium 14 to 
gateway 10. The data of the movies is compressed and may be encapsulated Into ATM cells or 

3 0 sent via DOCSIS MPEG packets or using any other suitable transport protocol that can 

provide the bandwidth, reliability, packet sequencing, error correction and other class of 
service factors needed for video data transmission. A downstream message is then sent to the 
gateway 10 telling it upon which logical channel it will be receiving particular requested 
data. 

3 5 Gateway 10 then tunes to that RF carrier, demodulates and detects the data on the 

designated logical channel on that carrier, packetizes the data into Ethernet or other LAN 

8 
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packets depending upon the LAN 28 protocol, and addresses the packets to the LAN and IP 
address of settop adapter circuit 36. The adapter 36 then receives the packets and buffers 
them in a buffer big enough to take out network latency, bandwidth limitations and jitter, 
decompresses the data and generates audio and video signals from the digital data for output to 
5 TV 34. Similar processing occurs for digital data requested by the other peripherals or the 
remote 30. Typical peripherals in a customer premises that the gateway couples to the 
headend circuitry that service them are: digital VCR 38, home computer 40, digital FAX 42, 
network computer 44, digital security video camera 46 and digital telephone or videophone 
48. 

10 In some embodiments, TV 34 and settop decoder 36 may have a private LAN to the 

gateway to get around bandwidth limitations and high traffic on LAN 28 that does not leave 
enough bandwidth for the video. 

In some embodiments, gateway 12 has intelligent hub management software that 
monitors traffic conditions and does whatever management and rate shaping is necessary to 

1 5 most efficiently use the LAN resources 28 and broadband resources 14 that are available. 

In some embodiments, the gateway 12 and settop decoder/adapter 36 can be combined 
into one unit that the TV 34 just plugs into. Likewise, the gateway may have individual 
output ports that each peripheral plugs into with signals formatted properly at each port for 
the type of peripheral that plugs into It. For example, instead of having digital telephone 

2 0 coupled to LAN 48, a standard telephone may be plugged Into gateway 12 with the gateway 

including ail the necessary circuitry to convert the signalling protocols and audio signal 
physical layer format of standard telephones to voice over IP or voice over DOCSIS service. 

The system of Figure 1 comprises any headend circuitry 12 which is appropriate to 
the type of transmission medium 14 in use and the type of servers and circuitry that 
25 provide the customer services. The transmission medium can be HFC, any type of digital 
suscriber loop lines (DSL) or standard PSTN telephone tip and ring lines or bidirectional 
satellite services such as Starband™ or the new version of DirecPC™ now in beta test or 
some combination of the two such as DirecTV™/DirecPC™ satellite service for the 
downstream and standard telephone line or DSL upstream. Some of these satellite services 

3 0 cannot send video on demand at this time or other high bandwidth services, but the system of 

the invention does not require video can be implement just broadband Internet access or 
other broadband, digital, non video based services. Accordingly transmission medium 14 
may be one or more data paths and may include different types of data paths such as CATV HFC 
for downstream transmissions and different upstream medium such as DSL or analog phone 
3 5 lines or satellite services for upstream transmissions. Preferably, both the upstream and 
downstream transmissions are carried out on the same medium using any form of 

9 
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multiplexing to separate upstream from downstream and any form of multiplexing to 
separate data to/from different customer locations. 

With regard to satellite medium, bidirectional broadband digital services exist or are 
in beta test such as Starband and the successor to DirecPC,, and unldirectlona video broadcast 
5 services such as Dish Network and DirecTV exist but no bidirectional video-on-demand 
services yet exist as far as the applicants are aware. Thus, if medium 14 is satellite, it may 
actually be two separate links and headend 12 may be two separate entities, one for 
bidirectional broadband digital traffic and one for unidirectional, downstream only digital 
video broadcasting. 

1 0 The headend circuitry can be connected to or contain any of a number of different 

services or networks. For example, the headend cherrypicker 12 may be connected to one or 
more of the following: the internet 16 via a WAN server in the headend; one or more video on 
demand servers 18; a public service telephone network interface 20; a T1 line interface 
22; or any other service 24 such as MP3 or game servers, security camera video 

1 5 monitoring circuitry, etc.; and analog cable television broadcast transmitters 26. 

Cherrypickers are well known and commercially available. Suitable circuitry for 
cherrypicker 12 is also disclosed in a U.S. patent application entitled HEAD END 
MULTIPLEXER TO SELECT AND TRANSMIT VIDEO-ON-DEMAND AND OTHER REQUESTED 
PROGRAMS AND SERVICES, serial number 09/602,512, filed 06/23/00, and another U.S. 

2 0 patent application entitled HEADEND CHERRYPICKER MULTIPLEXER WITH SWITCHED FRONT 

END, serial number 09/667,892, filed 09/22/00, both of which are assigned to the 
assignee of this application and both of which are hereby incorporated by reference. 
Further, each gateway disclosed herein may have an MPS or other digital audio server built 
Into the gateway itself or as an expansion module for the gateway. 

2 5 The headend cherrypicker 12 functions to receive commands from the gateway to 

order video-on-demand selections, browse the internet, dial a phone number, set up a video 
call or conference call, player game inputs, requests to download MPS selections, etc.. The 
cherrypicker 12 then carries out the appropriate actions and interfaces appropriately to 
the server or circuitry necessary to carry out the command and sends the appropriate 

3 0 digital data or analog signal downstream on medium 14. In the case of the analog CATV 

television signals, all these signals are broadcast on medium 1 4 separated by frequency 
division multiplexing, and gateway 10 just tunes to the appropriate channel, digitizes and 
compresses the video and audio and outputs it on local area network 28. Settop box 
converters then decompress the digital data and convert it to composite video or NTSC or PAL 
3 5 or SECAM format analog video signals for use by a television set. 
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Of course, LAN 28 may be implemented on the existing CATV wiring in the home or 
business, or CAT 5 wiring or lOBaseT, 100BaseT, 10Base2, Gigabit Ethernet, ATM, token 
ring or other LAN wiring or via wireless RF or infrared LAN systems currently available 
such as AlrPort, etc. If existing CATV wiring is used as the network, the analog CATV signal 
5 tuned by the gateway may be simply broadcast on the LAN in the frequency band devoted to 
analog signals and a different frequency band is used for transmission of digital data 
implementing other services. 

The function of the gateway 10 Is to receive commands from the intelligent remote 
30 and transmit appropriate commands and/or data to the headend cherrypicker to 
1 0 implement the command or interface functions needed locally satisfy the command. The 
gateway 10 also functions to receive digital data transmitted from the headend 12 and does 
all necessary processing and routing to output digital data as packets on local area network 
28 addressed to the correct peripheral. 

In alternative embodiments, the remote 30 may issue commands and receive data 

1 5 from settop decoder/adapter 36 coupled to the LAN and to television 34 and having suitable 

transceiver circuitry to talk to the remote 30. The commands are then packetized in the 
settop decoder 36 and sent to the gateway 1 0 via LAN 28 where they are routed to the 
headend 12 for implementation. 

Remote 30 can be a personal digital assistant that has been suitably programmed 

2 0 with a remote control program 50 and which has built into it or added to it by an expansion 

card such as a PCMCIA card or a Visor Handspring expansion card an infrared or RF wireless 
transmitter 52. Preferably, the remote control 30 is a custom circuit which includes all 
the necessary elements. The necessary elements of a remote according to the invention 
include at least a keyboard 54 or other input device such as a touchscreen, touchpad, mouse, 

2 5 joystick or other pointing device and displayed icons for commands or any other known way 

of entering input data into a computer, a computer 56 programmed with a remote control 
application 50 and a memory 58 or some circuitry that carries out the functions of the 
remote control application to receive operator inputs and transmit them to the gateway 1 0 
or settop adapter 36. In the broadest concept of the invention, the remote control does not 

3 0 need to have a display 60 and, therefore, it also does not need to have MPEG or other 

decompression programming or circuitry 62 nor does it need overlay program/circuitry 
64 or frame buffer 66. Although the display, keyboard, and transceiver are shown 
connected directly to the CPU, in reality, they are connected to address, data and control 
buses driven by the CPU through suitable, conventional driver or interface circuitry. 
3 5 The advantage of having display 60 and MPEG decompression software 62 and frame 

buffer 66 is that the remote control can be used to preview movies and the programs on 
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Other channels before purchasing the movie or changing the channel to the channel being 
previewed. The remote control 30 has its own address in the system as a separate 
peripheral. Thus, it can order and have video programs or game data or internet web page or 
e-mail data (or any other data supplied by the headend) sent directly to it. One of the 
5 advantages of having a remote with a display then is that the headend circuitry can send 
promotional trailers for video on demand movies, games, or other services to the remote 
control and can send the video of a channel designated by the remote to preview while the 
user is watching another channel on TV 34. 

The broadest concept of the invention is illustrated in Figure 2, and contemplates a 
1 0 remote control 70 without display that can issue wireless commands 72A to a headend 74 to 
invoke services provided thereby through one or more servers 76 that provide the requested 
service. Commands to the headend 74 and data sent in response thereto are transmitted 
through a broadband gateway or high data rate cable modem 78 in the home or through a 
settop box coupled to the high data rate gateway or cable modem. Wireless commands 72A or 

1 5 72B are transmitted to a settop decoder 80 or a cable modem 78 or gateway. The settop 

decoder 80 is coupled to a television 82 by video and audio wires 84 and is coupled to the 
cable modem by a local area network or USB or firewire or SCSI connection symbolized by 
bus 86. Commands 72A received from the remote are routed by the settop decoder 80 to 
cable modem 78 via bus 86 for routing to headend 74. These commands cause said headend to 

2 0 send digital data to one or more peripheral devices coupled to the gateway or cable modem 78 

such as settop decoder 80 or personal computer 88 which is also coupled to bus 86. The 
personal computer 88 can have broadband internet access via cable modem 78, transmission 
medium 14, headend cherrypicker 74 and internet server 90. 

Remote control 70 can have any of the structures of remote 30 in Figure 1 or it can 

2 5 be any other structure that can perform the functions attributed to it discussed herein. 

Remote 70 does not have a display or MPEG decompression circuitry or a frame buffer or 
any other circuitry to process incoming compressed video data in the preferred embodiment. 
In alternative embodiments, remote control 70 has a display, a frame buffer and MPEG or 
other decompression circuitry or software to decompress video and/or audio data and 

3 0 convert it to an analog signal format or digital data in a format that can be displayed. In 

other alternative embodiments, the remote also includes an optional speaker and/or 
earphone output jack represented by block 94 for playing decompressed audio data that has 
been converted to an analog sound signal. Of course suitable circuitry (not shown) to 
decompress audio data and convert it to an audio signal is present if the speaker and/or 
3 5 earphone jack are present. In this class of alternative embodiments, cable modem 78 or 
settop decoder 80 includes transceiver circuitry to transmit compressed video data to the 
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remote control of a channel to be monitored on the display of the remote control or internet 
protocol (hereafter IP) packet data to be displayed. The compressed video data is then 
decompressed and either displayed on the display or converted to a proper signal or digital 
format for display and displayed on the display of the remote. IP digital data from internet 
5 server 90 such as web pages, streaming video etc. can be transmitted in either compressed 
or uncompressed format from the settop decoder 80 or cable modem 78 and displayed on 
optional display 92, and upstream data such as e-mail messages, URL addresses are sent 
from the remote's transceiver to the transceiver in the settop decoder 80 or cable modem 
78. 

10 In some embodiments, the cable modem 78 and settop decoder 80 can be combined 

into one unit that the TV 82 just plugs Into. 

Cable modems with LAN outputs or other type bus outputs are commercially 
available, and suitable settop decoders are disclosed in the parent application. 

Figure 3 discloses limited use customer premises system utilizing a wireless remote 

1 5 control that controls a specialized TlVO-like gateway that interfaces a television to a 

satellite dish to receive digitized video broadcasts or video-on-demand data from a digital 
video headend elsewhere and interfaces the television and wireless keyboard remote to the 
public service telephone network for bidirectional IP packet data transfers to and from the 
internet via an internet server at the central office. The system of Figure 3 uses a remote 

2 0 control 1 00 in the form of a wireless keyboard or other infrared or radio frequency 

wireless remote control which allows e-mail data to be typed and URL addresses to be 
entered. The remote control 100 includes at least an infrared or RF transmitter to transmit 
data entered by the user to the specialized gateway 102. The gateway 102 is somewhat like a 
TIVO™ recorder, but, unlike the TIVO, gateway 102 incorporates a digital TV satellite 

2 5 receiver 106 in It. This digital TV satellite receiver can be any known design such as the 

receivers used in the DirecTV™ or Dish Network™ digital television broadcast services or 
any equivalent circuit. Receiver 106 has an input that can be coupled to a small satellite 
dish 1 04 through which downstream compressed digital video broadcasts are received. The 
receiver functions to demodulate and detect the compressed digital video and audio data 

3 0 broadcast on each logical channel by the satellite system digital video headend 108 along with 

channel and program descriptor auxiliary data. One difference of the incorporated receiver 
106 over the prior art DirecTV receivers etc. is that the prior art receivers contain 
circuitry to decompress the compressed digital video and audio data and convert it to analog 
video and audio signals but receiver 106 does not. These functions still need to be 
3 5 performed, but they are split out and performed in video decompression and conversion 
circuit 110 which is coupled to the receiver 106 and conventional modem 130 and 
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transceiver 128 through a router or crossbar switching circuit 112. The reason for this is 
that gateway 102 includes a hard disk 114 which is used to record compressed digital video 
and audio data to perform TIVO or UltlmateTV'^'^ functions, as described further below. To 
conserve hard disk space, the data output from receiver 106 on bus 110 is left in the 
5 compressed state so that operating system 116 and CPU 118 can order switching circuit 
112 to couple the output 120 of the receiver 106 to the input 122 of the hard disk 114 
when a program is to be recorded. In this manner, incoming digital video data can be 
recorded on hard disk 114 in compressed form. If the digital video data is to be simply 
viewed and not recorded, operating system 116 controls CPU 118 to control switch 112 to 
1 0 couple output 120 of the receiver 106 to the input 124 of the decompression and conversion 
circuit 110. Circuit 110 then decodes the MPEG digital video broadcast packets to generate 
uncompressed YUV digital video data which is then converted fn a video encoder (not shown) 
in circuit 110 to an analog NTSC, PAL or SECAM output video signal on line 126 for coupling 
to the video input of TV 82. Compressed audio is decompressed and converted in an audio 

1 5 processor (not shown) in circuit 110 to an analog audio signal for coupling to the audio 

input of TV 82. 

Operating system 116 cooperates with the remote control 100 to receive commands 
to implement TlVO-like functions using the same programming as is used in the TIVO in 
addition to the other programming needed to do the other functions of the gateway and control 

2 0 switch 112. 

These TIVO functions include any one or more of the following functions. Recording 
one or more video programs the user has specifically asked to record including timed 
recording and simultaneous recording. Timed recording allows recording in the future of 
specifically named programs using program guide data to identify the time and channel and 

2 5 duration. Timed recording also includes automatic recording at specified times on specified 

channels on specified days entered via remote control 100. Simultaneous recording allows 
the gateway to record two or more video programs simultaneously even if they are on 
separate logical channels (or different frequency carriers if two tuners or satellite 
receivers 106 are present) or to record one video program while simultaneously watching 

3 0 another program. 

Another TIVO function is indexing downloaded program guide data to organize it into 
categories such as sports, movies, documentaries, etc. and to display a menu from which 
programs can be picked to record. The menu allows searching by name so that the user can 
spell out a word on her remote control that is likely to appear in the name and all the 
3 5 programs with that word in the title will be displayed and can be selected for recording. The 
menu also allows browsing by time and browsing by channel to pick programs to record. The 
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menu also displays a category called "suggestions" which are shows the operating system 
thinks the user would want to record based upon learned characteristics of the user's 
viewing preferences. Shows from the suggestion list or from the search list or browsing 
lists can be selected for recording by a just selecting recording from a menu of actions such 
5 that "one touch" recording is implemented once that particular menu is reached. There is 
no need to define the day, week, channel and start and stop times thereby greatly simplifying 
the process. 

Another TIVO function is pausing, rewinding, fast forwarding and playing live TV 
programs In slow motion or normal speed. Another TIVO function is instant replay that 
1 0 jumps the program you are watching back in time by 8 seconds each time the wireless 
remote control instant replay button is pressed, and a slow motion command can be given 
when an instant replay is being played to do the instant replay In slow motion. 

Another TIVO function is to present a program banner at the time of the screen each 
time a channel change Is made to display overlay data that identifies the program, channel 

1 5 and start and stop times of a program in case channel surfing is being performed. 

Another TIVO function is providing the ability to record a program and any one of a 
plurality of selected quality or resolution levels. This is useful for watching sports at 
higher resolution than movies. 

Another TIVO function is receiving and recording user preference commands for 

2 0 automatic recording when they are watching programs. In other words, if a user is watching 

either a live or prerecorded program and finds it interesting, a "thumbs up" command can 
be given one, two or three times to indicate the level of interest in this type of program. 
Another TIVO function is receiving and recording "thumbs down" commands for live or 
prerecorded shows the user finds not interesting. These "thumbs up" and **thumbs down" 

2 5 commands received from the user's remote allow the gateway or headend cherrypicker 

implementing the TIVO functions to do automatic suggestion of programs that the operating 
system thinks the user would like to record based upon learned patterns of viewing by this 
user based upon past recordings and user preferences as indicated by previous "thumbs up" 
and "thumbs down" commands given. These suggested programs are listed in the order of 

3 0 closeness to the perceived pattern of user preferences learned by the operating system. Any 

program on the suggestion list may be easily set up for recording by using wireless remote 
1 00 in Figure 3 to pick a "record this showing" menu command from a menu displayed on 
TV 82, 

Another TIVO function is freeze frame and slow motion playback of recorded 
3 5 programs and high speed fast forwarding at one of multiple selected speeds to wind through 
commercials or other segments the user does not wish to watch. 
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Another TIVO function is the "season pass" wherein each time an episode of a 
specifically named program is broadcast on any channel on any medium to which the gateway 
is connected, the program is recorded. 

Another TIVO function is a menu of the best programs and network showcases 
5 programs that will be broadcast in the next few days by the broadcast networks and a menu 
that allows quick setup for recording these shows. 

Another TIVO function is the ability to configure the system to download program data 
for only the channels to which a user has subscribed. 

Another TIVO function is displaying of a menu of programs that have been recorded 
1 0 and providing a menu to issue commands to play a program, delete it, save it until a specific 
date or save it until It is specifically deleted by the user. 

Another TIVO function is to save the place where a user stopped viewing a program 
when the user stops watching a prerecorded program. The next time the user resumes 
watching that particular program, play starts from where she left off. 

1 5 Another TIVO function is automatic downloading of program guide data via 

conventional modem 130 so the operating system knows what programs will be broadcast 
when on each logical channel on each medium to which the gateway is connected. 

Another TIVO function is pausing live TV for a bathroom break, a phone call, etc. so 
that the program can be recorded and -watched virtually simultaneously off the data recorded 

2 0 on the hard disk. 

Another TIVO function is to display program guide data downloaded from a program 
guide server via modem 130 on said television 82. 

A TIVO function that is not implemented is outputting of infrared commands to an 
infrared transducer affixed to an external digital video broadcast receiver to change the 

2 5 channels thereof in response to channel selection commands entered by remote control 100. 

This is a significant advantage because the TIVO prior art system gets confused and often 
records no signal at all when an uninitiated family member such as a child changes the 
channel on the separate digital TV satellite receiver using that receiver's remote control 
instead of the TIVO controller. This confuses the TIVO prior art system since if the channel 

3 0 is changed without using the TIVO controller, the TIVO system does not know to which channel 

the dish receiver is currently tuned. Strangely, the TIVO prior art system tunes an external 
digital video satellite receiver by sending it infrared "differential" commands. Thus, if the 
TIVO knows the receiver is tuned to channel 1 00 and the TIVO wants to record a program on 
channel 125, the TIVO will issue a command to Increase the channel number by 25 either by 
3 5 giving 25 channel up commands or by giving a command to increase the channel number by 
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25 instead of simply giving a command "change to cliannel 125". This is a serious drawback 
if small children or TlVO-challenged people are using the TV. 

Instead, operating system 116 receives wireless channel change commands from 
remote control 1 00 and sends control signals to receiver 1 06 to cause it to tune to the 
5 selected channel. Computer 118 is coupled to all circuits in the gateway 102 to control 
them via data, address and control lines (not shown) under the control of operating system 
116. 

The remote control 100 includes buttons, keys or displayed icons that can be invoked 
to control the gateway to implement each one of these functions. The operating system can 

1 0 implement all the other TIVO functions also as well as control the gateway to use the remote 

control and TV as a computer to browse the internet. This collection of TIVO functions is 
referred to in the claims as TIVO functions. 

Decompression and conversion circuit 110 also serves to receive uncompressed data 
in IP packets from modem 130 and remote control 100 through receiver or transceiver 
15 128 and convert It to NTSC, PAL or SECAM video (and possibly analog audio) signals for 
display on television 82. This allows the remote control, gateway and modem and TV to 
function as a personal computer and modem combination to view web pages, search the 
internet and send and receive e-mail without actually needing a computer. 

Receiver 106 has the ability to tune and demultiplex two separate logical channels 

2 0 simultaneously in some embodiments. Typically, this will be done by filtering out all MPEG 

packets having two separate program descriptors (PID) and providing these MPEG packets to 
switching circuit 112. The packets for the two different PIDs can be sent to different places. 
For example, all the filtered out packets can be sent via switch 112 to operating system 116 
which has previously received commands from remote 1 00 to view the program identified 
25 by a first PID on TV 82 and to record a program identified by a second PID on hard disk 114. 
The operating system will then transmit all packets containing the first PID to switch 112 
and control switch 112 to route those packets to decompression and conversion circuit 110. 
The operating system then may simultaneously or later output the packets containing the 
second PID to switch 112 and control switch 112 to route these packets to hard disk 114 for 

3 0 recording. Likewise, one program's packets can be routed to decompression and conversion 

circuit 1 1 0 for viewing on TV 82 and another program's packets can be routed to remote 
control 100 for monitoring on an optional display therein. Remote control 100 may have 
any of the structures of remote control 70 in Figure 2 or simply be a keyboard coupled, in 
some embodiments, to packetization circuitry to packetize the commands into IP packets, and 
3 5 an infrared or RF transmitter. 
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In alternative embodiments, the switch 112 will have routing capabilities based 
upon routing tables built therein by the operating system 116 based upon command received 
from remote 100. The router will then look at the PIDs in all incoming packets from 
receiver 106 and route them according to the data in its routing tables thereby eliminating 
5 the intermediate step of sending all packets to the operating system 116 and the need for the 
operating system 116 to buffer these packets while waiting to retransmit them. 

Commands from remote control 100 are received by transceiver (if the remote has a 
display) or receiver (if the remote has no display) 128 and are coupled to switch 112 
where they are routed automatically to the operating system. In alternative embodiments, 
1 0 the transceiver 128 may be coupled to switch 112 through local area network 86. In other 
words, the transceiver may have a network interface circuit and be out somewhere on the 
home network LAN 86. The transceiver then receives wireless commands from the remote 
control and those commands are packetized into LAN packets and routed or sent to NIC 164 
which then routes them to switch 1 1 2 for routing to the appropriate destination such as 

1 5 operating system 116. Data to be sent to the remote is routed to NIC 164 and then sent over 

LAN 86 to the transceiver where it is transmitted wirelessly to the remote. The LAN may be 
any type of layer 1 and layer 2 protocol run over any existing wiring in the home or over 
LAN wires that have been added. For example, the LAN may be run on CAT 5 wiring, the 
existing CATV coax in the home, over the house's power lines or phone lines or by any 

2 0 conventional RF or infrared wireless LAN technology such as Blue Tooth (short distance, low 

power) or 802.11 (larger distances for office environments), etc. LAN technologies are 
commercially available from many sources including some of the newer technologies with 
proprietary protocols at layer 1 and 2 available from Inari, Itran and itellon. NIC 164 and 
the NIC of the transceiver will be whatever is needed for the type of medium and protocols in 

2 5 use. in the claims, limitations regarding receivers or transceivers coupled to the switch for 

communicating with a wireless remote or words to that effect are intended to cover these 
embodiments where the transceiver is coupled to switch 112 via LAN 86. 

The operating system then analyzes each command and outputs a suitably formatted 
command to switch 112 and controls switch 112 to route the command to the appropriate 

3 0 circuit. In some embodiments, operating system 116 may packetize commands to be sent to 

the internet such as requests to download web pages or send or receive e-mail as IP packets 
addressed to the appropriate IP address. In other embodiments, the remote control itself 
packetizes internet commands into IP packets. Wherever these internet commands get 
packetized, they are routed by switch 112 to a conventional PSTN modem 130 where they 
3 5 are transmitted over a PSTN subscriber loop 132 to a central office internet server 134. 
There, they are launched on a route to the appropriate server on the internet. The central 
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office also includes a program guide server to download program guide data to gateways on a 
regular basis for storage therein so that each gateway knows which programs are going to be 
broadcast when on each logical channel of each medium to which the gateway is connected. 

Referring to Figure 4, there is shown a system that uses a satellite link for 
5 unidirectional downstream digital video transmissions and uses a gateway coupled to a hybrid 
fiber coaxial network of a cable television system for provision of bidirectional high speed 
internet access and other broadband services. The fundamental notion of the system species 
of Figure 4 is that broadband, digital video links via DirecTV and Dish network already exist 
and work well so there is no point in using up valuable bandwidth on the HFC network for 
1 0 digital video transmissions when that bandwidth can be used to provide high speed internet 
access and other broadband services such as centralized security camera monitoring of 
customer premises from the headend, interactive game playing with a game server at the 
Ineadend, audio-on-demand from an MPS or other digital audio server at the headend, etc. 

The system uses a home gateway 10 which is coupled by a local area network 86 to 

1 5 one or more peripherals. These peripherals include a personal computer 88, a settop 

decoder 80 coupled to a TV 82 by analog audio and video signal lines 84, and a digital video 
security camera 46. The gateway 10 is also connected to a digital video headend video server 
108 via a satellite uplink and downlink and a satellite dish 104. The gateway 10 
incorporates tuner, demultiplexer and authorization circuitry from conventional digital 

2 0 video satellite receivers therein, but the decompression circuitry to decode the MPEG or 

other compression to YUV format digital data and conversion circuitry to convert the YUV 
format and other audio and/or auxiliary digital data of digital TV broadcast program to analog 
NTSC, PAL or SECAM video signals is placed in the settop decoder 80. This allows the 
network 86 to carry only compressed digital video data in packets. Settop decoder 80 also 

2 5 includes a network interface card (NIC) to pluck LAN packets off network 86 addressed to it. 

The personal computer and security camera 46 also include NICs to send and receive 
packetized LAN data addressed to each device over LAN 86 with the gateway 10, 

Optionally, if pay-per-view events are to be requested, gateway 10 includes a 
conventional modem to transmit data to digital video headend 108 over the PSTN 142, These 

3 0 commands are entered wirelessly via remote control 70 via RF or infrared transmission 

circuitry in the remote and gateway. The remote control, in the preferred embodiment, 
includes a display 92 and audio transducers and/or earphone jacks 94, but in more basic 
embodiments, does not. Commands from the remote 70 may also be routed to the digital video 
headend 108 via the HFC 144, headend cherrypicker 74 and a PSTN interface 146 in the 
3 5 form of a conventional modem which is internal or external to the cherrypicker 74. The 
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cherrypicker can be any conventional cherrypicker or the cherrypickers disclosed in tfie 
patent applications incorporated by reference lierein. 

The cherrypicker Is coupled to a video server 76, an internet server 90, a game 
server 148, a security camera server 150 coupled to a plurality of security monitors 152 
5 and an MPS or other digital audio server 154 to provide audio-on-demand services. The 
cherrypicker 74 functions to receive commands from the remote control 70 or other 
command console or personal computer couped to gateway 10, The cherrypicker responds to 
these commands by issuing the proper commands to the proper server to cause transfer of 
digital data from the server(s) to the gateway 10 and the requesting peripheral over LAN 86 
1 0 or the wireless connections 72A or 72B to the remote 70. 

Figure 5 is a block diagram of one embodiment for a gateway 10 in Figures 1 and 4 
which have the ability to implement TIVO functions as well as interface the peripherals 
coupled to the gateway to two different broadband digital data delivery systems, specifically, 
digital video data broadcast systems and high bandwidth digital data services delivered over 

1 5 and HFC cable plant. The gateway 10 is quite similar to gateway 102 of Figure 3 except that 

gateway 10 includes a cable modem 160, a rate shaping circuit 161 and a local area network 
network interface card or external bus transceiver 164. It may also, optionally, include an 
MP3 server 163. 

The cable modem 160 can be any of the existing cable modems Including DOCSIS cable 

2 0 modems. In some embodiments, a DSL modem can be substituted for the cable modem for 

high bandwidth exchanges with the headend over DSL lines instead of HFC. In other 
embodiments, a bidirectional, high bandwidth satellite modem such as a Starband modem may 
be substituted for cable modem 160. In other embodiments, a wireless local loop modem 
may be substituted. In still other embodiments, one or more of these different types of 

2 5 modems may be simultaneously present through a modular plug in connection to the gateway 

or all may be present permanently incorporated into the gateway circuit. All of these 
different combinations are referred to in the claims as a "high bandwidth digital data 
communication means". All of these possibilities will hereafter be referred to as simply the 
"cable modem" even though it might be a satellite or DSL modem or a combination of 

3 0 multiple high bandwidth modems and multiple high bandwidth data paths. 

The cable modem 160 is coupled to switching circuit 112. This allows incoming IP 
packet data or MPEG packets containing IP packets or video and audio and auxiliary data of 
television programs or other services to be routed to the correct destination circuit under 
control of operating system 116. The control computer 118 and operating system 116 (the 
3 5 operating system refers to all the computer programs needed for the various applications 
that the gateway can perform and not just the bare operating system like Windows, MAC OS, 
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Solara, Linux, etc. although the bare operating system is part of the computer programs 
referred to by blocl< 116). The control computer also can control the cable modem 160 to 
automatically download program guide data from a source at the headend or from a source on 
the internet through a web server at the headend in embodiments where the conventional 
5 modem 130 is not used for this purpose. 

One new destination circuit to which the data from either the cable modem 160 or 
operating system 116 or transceiver 128 or conventional modem 130 or decompression and 
conversion circuit 110 may be routed is local area network interface card or bus 
transceiver 164 (hereafter NIC 164). NIC 164 receives digital data in IP or MPEG packet 

1 0 format or any other format and encapsulates it into LAN packets (such as Ethernet packets) 

or cells (such as ATM cells) for transmission to the peripherals coupled to LAN or bus 86 or 
to a LAN hub or switch. The LAN 86 can be one or more LANs and can be managed by an 
intelligent hub, a switching hub or a dumb repeater hub, so NIC 164 will be whatever 
interface is necessary for the type of LAN 86 is. 
15 In case line 86 representa a bus, the incoming data to NIC 164 is transmitted to the 

peripherals using whatever bus protocol is native to bus 164. Thus, with gateway 10, a 
user can use the remote 70 in Figure 4 to control viewing on TV 82 of digital video 
broadcasts and simultaneously use remote 70 or personal computer 88 in Figure 4 to 
control broadband browsing of the internet via cable modem 160 and NIC 164 and/or to 

2 0 invoke TIVO functions. In some embodiments, conventional modem 130 is used only to 

automatically or manually download program guide data from a program guide server 162 
via a conventional phone line to support the TIVO functions gateway 1 0 performs in the same 
manner as gateway 102 in Figure 3. 

One additional function that gateway 10 can perform is to receive IP or MPEG format 

2 5 packet data encoding video program data or broadband internet access or other broadband 

servers received from the headend cherrypicker 74 via the high bandwidth digital data 
communication means. The computer 118 controls switch 112 to supply the broadband data 
to any destination including the rate shaping circuit. Likewise, high bandwidth data from 
any source including the rate shaping circuit 161 may be routed to the high bandwidth 

3 0 digital data communication means 160 for transmission upstream. For example, received 

high bandwidth video data can be routed to the decompression and conversion circuit 1 1 0 for 
viewing on TV 82 or to NIC 164 for transmission to a peripheral or to transceiver 128 for 
transmission to the remote for viewing on the remote's display. The decompression and 
conversion circuit strips the payload data out of each such packet and does a reverse 
3 5 segmentation and reassembly process and converts the resulting data to analog video and 
audio signals for output on video and audio lines 126 and 127 for display on television 82. 
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This allows such things as games being run on a headend game server to be displayed on 
televisions at customer premises and allows video-on-demand or other video-based services 
provided by a video server at the headend {e.g., 76 in Figure 4) to be ordered by the 
wireless remote and displayed on television 82 or sent to a computer coupled to NIC 164. 
5 Note that when the gateway of Figure 5 is used as gateway 10 in Figure 4, the 

functions of settop decoder 80 are performed by decompression and conversion circuit 110 
in Figure 5 so the settop decoder 80 is not present in Figure 4 and the TV 82 plugs directly 
Into the gateway 10. 

The gateway of Figure 5 also has a rate shaping circuit 161 which is coupled to 

1 0 switch 112. This rate shaping circuit is one or more transcoder integrated circuits and any 

needed support circuits, it functions to receive high bandwidth data and alter the data rate to 
match the available bandwidth of the data path on which the data is to be transmitted. The 
rate shaping circuitry is controlled by computer 118 to alter the bandwidth of data routed 
through it by switch 112 to match the available bandwidth of whatever data path the data is 
15 to be transmitted on. This allows bottienecl<s on LAN 86 or the medium 144 to the headend to 
be managed by lowering the data rate of the data to be transmitted. Since the data rate of 
compressed video programs varies with the amount of motion in the picture, the transcoders 
161 allow the variable data rate to be altered to match the available bandwidth of the data 
path. The headend CMTS circuitry knows how much bandwidth is available on HFC 

2 0 downstream and upstream at any particular time at least in DOCSIS cable modem systems 

since the headend assigns bandwidth and the total available bandwidth on the HFC is fixed. 
Likewise, the gateway control computer 118 knows how much bandwidth is available on LAN 
86 at any particular time since computer 118 controls the routing of data onto LAN 86. 

Referring to Figure 6, there is shown a block diagram of the preferred architecuture 

2 5 for a cable headend to perform TIVO functions for each customer at the headend. The headend 

of Figure 6 also delivers to customers internet or other non video data such as internet 
protocol packets from internet servers 284 or any of the other servers to which the headend 
circuitry is connected (hereafter iData). The headend also delivers to the customers video- 
on-demand data (hereafter VOD) and/or broadcast or "pushed" video programs (video 

3 0 programs from a video server at the headend which are broadcast at regularly scheduled 

times) supplied by broadcast networks 280 or near video on demand video servers 281 to 
customers via HFC 250. 

The downstream and upstream path to the customers is a shared hybrid fiber coax 
(HFC) cable plant 250. A plurality of network cherrypicker multiplexers 252 through 
3 5 through 262 marked NCR function, inter alia, to send Ethernet packets to the packet switch 
210 telling it which MPEG packets transporting data for a particular desired program or 
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service each cherrypicker switch wants. Each requested pacl<et is defined in terms of an 
Ethernet station address. Video programs broadcast by networl<s 280 via satellite and 
provided by near VOD video servers 281 or video on demand servers in server farm 282 and 
data provided by other servers in server farm 282 are in IViPEG transport streams with 
5 packets encoding a particular program or service each have a program identifier or PID that 
identifies that program or service. The same is true for iData encapsulated in MPEG packets 
in l\/IPEG transport streams output by servers In application server farm 286 or by web 
servers in cloud 284. Each of these video data and IData sourqes outputs MPEG transport 
streams having PlDs therein, and is coupled to packet switch 210 by an IP wrapper circuit 
1 0 such as 276, 278 or 279. The function of the IP wrapper circuits is to break the MPEG 
transport streams on input lines 283, 285 and 287 up into individual MPEG packets and 
encapsulate these MPEG packets in multicast IP packets. These IP packets are themselves 
then encapsulated by the IP wrapper circuits into Ethernet packets addressed to an Ethernet 
station address that corresponds to the PID. Every audio, video or IP data packet source can 

1 5 have its own unique Ethernet station address and can be requested by the NCPs using that 

Ethernet station address. In alternative embodiments, every MPEG transport stream 
multiplex has its own unique Ethernet station address. Each such multiplex would carry 
MPEG packets from a plurality of programs, each program having its own unique PID. 

TIVO functions are Implemented using hard disk array 289, packet switch 210 and 

2 0 system control computer 244. The hard disk array receives MPEG compressed data packets 

to be recorded via bus 301 output from an IP dewrapper circuit 305. The IP dewrapper 
305 receives MPEG video data packets encapsulated in IP packets which are encapsulated in 
Ethernet packets on bus 307. The IP dewrapper 305 strips off the Ethernet and IP packet 
headers and outputs MPEG packets on bus 301 . MPEG data packets encoding TIVO function 

2 5 menus and recorded video programs are output on bus 303 to IP wrapper circuit 276 where 

they are wrapped in IP multicast packets and Ethernet packets having Ethernet station 
addresses corresponding to the PIDs of the MPEG packets output on bus 303. 

Hard disk array 289 is segmented into multiple storage areas, each area dedicated to 
implementing TIVO functions for one subscriber. Menu data may be stored in a common 

3 0 shared area. Menus to be displayed on the televisions at the customer premises to allow TIVO 

functions to be invoked have one or more PIDs assigned to them. These menus are output as 
MPEG streams on line 291 from the hard disk array to IP wrapper circuit 276. The same Is 
true for MPEG streams encapsulating programs that have been recorded at the customer 
request or live TV programs the customer is watching and wants to use TIVO functions on 
3 5 such as slow motion, instant replay, stop, fast forward or rewind. The IP wrapper circuit 
encapsulates these menus, live program data and auxiliary data, and prerecorded programs 
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into multicast iP packets. Tiiese IP packets for eacfi PiD are then tliemselves encapsulated 
into Ethernet packets addressed to an Ethernet station address that corresponds to the PID. 
Thus, the customer can use his wireless remote at his premises to request TIVO menus and 
Invoke TIVO commands record programs, search for programs, and do all the other TIVO 
5 functions. 

Each NCP receives from control computer 244 information about which programs 
and or services including data for displays of menus needed to invoke TIVO services or TIVO 
recorded programs customers have requested. These requests are made using the wireless 
remotes such as remote 30 in Figure 1 and transmitted upstream from the customer 
1 0 gateways and are received via cable modem 246 in the headend 12. The requests are routed 
by switch 210 to management and system control computer 244. The control computer then 
assigns the requested data to a particular logical channel and sends a downstream message via 
cable modem 246 to the customer telling that customer's gateway to which logical channel to 
tune to receive the requested broadcast or VOD or TIVO recorded video program, service data, 

1 5 TIVO menu, etc. The requested data is then displayed on a television, computer, game system 

etc. coupled to the gateway. The management and control computer 244 then controls switch 
210 to route the requests to whichever NCP has been assigned to service the request 
according to the channel assignment. The NCP then sends a request packet to the packet 
switch 210 which identifies the requested program, menu etc. by the corresponding 

2 0 Ethernet station address. Packet switch 210 functions to receive the packets from each NCP 

designating which Ethernet station addresses for which it wants packets sent to it. The 
packet switch 210 then sets up a data path and routing table or other routing circuitry in 
the to route packets with the designated Ethernet stations addresses out on the proper LAN 
segment to the cherrypicker switch that requested them. Any Ethernet packets output by IP 

2 5 wrapper circuits 276, 278 or 279 having the requested Ethernet station address are then 

routed to the NCP that requested it. 

Each NCP transmits a different MPEG transport stream encapsulated in IP packets 
encapsulated in Ethernet packets in embodiments where the gateway that can receive 
Ethernet packets containing IP packets containing MPEG packets and strip off the Ethernet 

3 0 and IP packet headers, repacketize them into LAN packets for whatever network is coupled to 

the gateway and route them to the settop decoder of the correct peripheral. The settop 
decoders must have the capability to decompress the MPEG packets to generate video and/or 
audio signals. In embodiments where the gateways are not capable of receiving data in this 
format or the downstream medium transport stream cannot handle data in this format, an IP 
3 5 dewrapper circuit (not shown) is used for each NCP or shared by them all. The IP 

dewrapper circuit(s) function to strip off the Ethernet and IP packet header information and 
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sort out the different MPEG transport streams and route them to the appropriate FDMA 
channel and logical channel therein of the appropriate downstream HFC transmitter (or DSL 
modem or satellite uplinl< transmitter in other embodiments). 

The packet switch 210 sends to the cherrypicker switches only the packets that have 
5 been requested- This is different than the prior art cherrypicker structure with splitters 
where each cherrypicker switch received MPEG stream packets from the splitters that had 
to be rejected because they were not for programs the cherrypickers wanted. This is one 
fact that improves the performance and scalability of the cherrypicker system of Figure 6. 
By using packet switch 210 instead of splitters, less processing time is wasted in the 
1 0 cherrypicker switches rejecting packets that will not be incorporated into the MPEG 
transport streams each cherrypicker switch is generating. 

The cherrypicker switches have front end processing circuitry and software that the 
prior art cherrypicker multiplexers did not have to be able to receive LAN packets 
encapsulating TCP/IP packets. The cherrypicker switches also recognize the LAN addresses 

1 5 and TCP/IP addresses and use that information generated from the PIDs to sort the incoming 

packets into one or more MPEG transport streams going to video-on-demand and/or 
customers who have requested internet data or other data from servers coupled to the packet 
switch 210. The cherrypicker switches 252 through 262 also optionally recede at least the 
VOD and/or other video program data to the proper bandwidth for the downstream available 

2 0 bandwidth and repacketize the receded data into MPEG packets. This receding can be done by 

integrated circuits commercially available from the assignee of the present invention. In 
some embodiments, the cherrypicker switches packetize the MPEG packets into UDP/IP 
packets and Ethernet packets addressed to an optional separate, shared IP dewrapper circuit 
21 1. The IP dewrapper circuit strips off the LAN and UDP/IP packet headers and 
25 reassembles each MPEG transport stream and outputs it on bus 213 to the proper 

transmitter 264, 266, 268, 270, 272 or 274 for downstream transmission. In other 
embodiments, each NCP 252 through 262 has its own IP dewrapper circuit. In other 
embodiments, each NCP outputs one or more MPEG transport streams wrapped in IP packets 
directly to its own transmitter(s). 

3 0 Cable modem 246 sends non video data downstream and receives upstream commands 

and data from the gateway and remote control at each customer premises. Cable modem 246 
is comprised of an upstream receiver 247 and a downstream QAM modulated transmitter 
249. The receiver 247 receives upstream VOD requests and upstream iData and wireless 
commands to invoke TIVO functions. The cable modem transmitter 249 transmits command 
35 and control messages downstream that tell each gateway on which logical channel to find its 
requested data. Cable modem transmitter 249 also sends iData downstream to provide 

25 
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broadband internet access and other services, in otfier embodiments, tlie command and 
control messages and/or iData is transmitted downstream via the cherrypicl<ers and their 
associated downstream cable modems marked 264 through 274. In some embodiments, the 
cable modem 246 is used also to transmit and receive voice-over-IP packets when packet 
5 switch 210 has an interface to the PSTN. 

The cable modem 246 can be any conventional cable modem design and many different 
types are commercially available. The preferred embodiment for the cable modem is any 
DOCSIS modem or the cable modem defined in EPO patent publication 0955742 published 10 
November 1999 or EPO patent publication 0858695 published 19 August 1998, both of 
1 0 which are hereby incorporated by reference. 

Cable Modem Termination System (CMTS) 276 is conventionally designed circuitry 
that, for the preferred embodiment, does all the interleaving, insertion of time stamps, 
ranging, training, adaptation of receiver amplitude and phase correction factors from 
preamble data etc. needed to support the receiver and transmitter of the cable modem. A 

1 5 suitable CMTS circuit is disclosed in U.S. patent application entitled APPARATUS AND 

METHOD FOR SYNCHRONIZING AN SCDMA UPSTREAM OR ANY OTHER TYPE UPSTREAM TO AN 
MCNS DOWNSTREAM OR ANY OTHER TYPE DOWNSTREAM WITH A DIFFERENT CLOCK RATE 
THAN THE UPSTREAM published as EPO publication 0955742 on 10 Nov. 1999. 

Packet switch router 21 0 is conventional in structure and routes LAN packets on a 

2 0 LAN links 277 to the cable modem 246 and on LAN links 279, 281, 283, 285, 287 and 289 

to all the NCPs. The packet switch router is also coupled by LAN links 291, 293, 295 and 
297 to multiple sources of Ethernet or other LAN packets encapsulating IP packets 
encapsulating MPEG video data and IData . MPEG video data or IData encapsulated in UDP/IP 
packets encapsulated in LAN packets addressed as previously described are supplied to the 

2 5 packet switch 210 from IP wrapper circuits 276, 278 and 279. IP wrapper 276 

encapsulates MPEG packets from MPEG transport streams supplied from broadcast sources 
such as satellites and other cable system headends, as represented by cloud 280. IP wrapper 
circuit 283 also wraps MPEG packets for TIVO menus and TIVO video services coming from 
hard disk array 289. IP wrapper circuit 276 also wraps MPEG video packets from near 

3 0 VOD servers 281. IP wrapper circuit 278 supplies LAN packets encapsulating MPEG video 

packets and other TCP/IP packets supplied from servers in server farm 282. IP wrapper 
circuit also serves to receive LAN packets addressed to web servers in internet cloud 284 
and other servers in server farm 282 and to strip off the LAN packet headers and IP headers 
and output MPEG packets to the servers. 
3 5 The servers in server farm 282 include VOD servers, game servers, EMM servers 

that supply weather, news, stock market data and messages associated with TV programs. 
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electronic program guide servers, Tmail servers that display e-mail on customer TVs, data 
carousel servers, and TlVO-iike personal video recorders in alternative embodiments where 
the TiVO functions are implemented by one or more servers at the headend instead of being 
controlled by system control computer 244. Server farm 282 can also include banks of 
5 transcoder servers to adjust the data rate of various streams of data. These transcoder 
servers receive MPEG packets of video, TIVO menus or IData to be transmitted downstream to 
a customer and reduce the data rate according to rate shaping commands received from the 
system control computer to match the available bandwidth for transmissions to the customer 
who requested the data. The rate adjusted data is then sent to the packet switch and routed to 
1 0 the appropriate NCP and transmitter for downstream transmission. 

Near video on demand servers 281 are servers that broadcast pay-per-view video 
programs on a frequent basis, usually the same movie over and over. Personal video 
recording servers are TIVO servers at the head end that record video programs requested by 
users in upstream requests and perform the other TiVO functions such that each customer 

1 5 can have a personal TiVO space at the head end with the TIVO functionality implemented by 

shared hardware and software. Other types of servers in the server farm can include web 
servers that convert HTIVIL packets from the web servers in internet cloud 284 or from web 
servers in the server farm 282 to IVIPEG or other data formats so that users without 
computers can surf the web using their TVs and wireless keyboards or wireless remotes or 

2 0 other devices. Tmall servers are computers that convert e-mail messages to l\/IPEG or other 

video data that can be converted to a video signal that can be displayed on a user's TV to allow 
the user to send and receive e-mail using their TVs and using wireless keyboards or 
wireless remotes. Data carousel servers serve up data similar to teletext messages. 
Transcoder servers transform streaming video and streaming audio TCP/IP packet streams 

2 5 into MPEG 2 or MPEG 4 transport streams and convert MPEG 1 transport streams to MPEG 

2 transport streams, and convert quicktime and real player formatted data in TCP/IP 
packets to MPEG 2 or MPEG 4 transport streams. 

The packet switch router 210 also receives LAN packets encapsulating TCP/IP 
packets from web servers in internet cloud 284 and from applications servers in 

3 0 application server farm 286. These packets are encapsulated in MPEG packets and are 

encapsulated by IP wrapper circuits 278 and 279 into LAN packets for routing by packet 
switch 210. The web servers allow users at home or in the office with their computers to 
have internet access through the HFC plant 250 at much higher speeds than dial up 
connections to ISPs. 

3 5 The application server farm 286 can include advertising servers that send 

advertisements out to customers via MPEG transport streams or TCP/IP streaming audio or 
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video or other formats. The application server farm 286 can also include Tcom servers that 
send and receive packets that allow customers to carry out telephone or videophone 
communications from their computers or televisions using wireless keyboards or wireless 
remotes to dial and microphones and speakers in the wireless keyboards or wireless 
5 remotes. The Tcom servers interface to the public service telephone network or high 

bandwidth services like T1 , partial T1 , frame relay or point to point networks and share the 
capacity thereof through the head end and do the packetization and depacketization necessary 
to provide voice-over-IP. The application server farm 286 can also include game servers 
that send and receive packets that allow customers to play games on the game server at the 
1 0 head end remotely from their computers or televisions at home. Other possibilities are chat 
servers that allow customers to enter chat rooms on the internet or local chat rooms 
restricted to the customers of the cable system, and statistical servers that serve up any 
kind of statistical Information. Other possibilities are security servers that send and 
receive packets that carry MPEG video data from security cameras in user's homes or 

1 5 offices that can be viewed by security service personal at the head end, and banking servers 

that allow customers to carry out electronic banking from their computers or televisions at 
home. 

A management and system control computer 244 functions to control and coordinate 
operations within the head end to supply the above mentioned services including, fn some 

2 0 embodiments, implementing the TIVO functions, as described above. In addition to the 

functions of routing VOD requests and sending downstream messages to implement VOD, 
computer 244 also sends messages to transcoder servers in server farm 282 to control the 
bandwidth of the recompression processing. In some embodiments, each NOP Includes its 
own transcoder. In addition, computer 244 also performs the following functions: manage 

2 5 subscribers to verify subscribers are authorized to receive what they have requested; send 

encryption key messages to the transmitters of the cable modem and cherrypicker 
transmitters to encrypt iData and video program data that customers have ordered so only 
the customers who have subscribed or paid can view or use the data; provisioning and 
directory management; network management such as bandwidth allocation and load balancing; 

3 0 reporting and analysis for management purposes; data management; and call center 

operations and other customer support functions. In addition, computer 244 coordinates 
with CAS system 288 and billing system 290 manage payment for services rendered. 

Figure 7 Is a block diagram of a more generalized architecuture for a cable headend, 
central office or satellite uplink facility, represented by cloud 292. This headend facility 
3 5 can deliver IData and VOD and/or broadcast video data to customers and perform TIVO 
functions for each subscriber via HFC, DSL or satellite. The embodiment of Figure 7 
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perform TIVO functions for each customer using one or more personal video recorder (PVR) 
servers at in application server farm 286. These servers implement all the TIVO functions 
identified above using their own computers and hard disk storage by cooperating with system 
control computer 244 to control pacl<et switch 210 to route video packets to be recorded to 
5 the PVR servers. The switch 210 is also controlled to route video packets encoding TIVO 
menus and recorded program playback data to customer gateways via the appropriate NOP 
and transmitter. 

Referring to Figure 8, there is shown a block diagram of an advanced home gateway 
with built in TIVO video server, multiple broadband interface capability, multiple LAN 
1 0 interface capability and built in email, web server, answering machine, voicemail and PBX 
functionality, This gateway has a front end section 300 which includes one or more 
broadband interface circuits and a remote transceiver for wireless communication to a 
wireless remote control. These preferably are modular for expandibility, and can Include: 
an HFC pure SCDMA cable modem, a DOCSIS 1 .1 or 1 .0 or other DOCSIS cable modem, a 

1 5 digital satellite receiver or transceiver such as a Dish Network receiver or Starband 

modem, a terrestial broadcast tuner, a wireless local loop transceiver, OC-1 or OC-3 
interface transceivers, and/or XDSL (any Digital Subscriber Line) modem. The front end 
300 also includes a wireless remote interface for bidirectional communication with a 
remote (not shown). In some embodiments, block 300 can include one or more conventional 

2 0 analog tuners to tune to selected frequency division multiplexed analog CATV broadcasts and 

provide the analog signals regular televisions without settop adapters coupled to the gateway 
by dedicated coaxial cable lines and/or a single coax lines and splitters for drop lines to each 
TV. This provides a standard CATV decoder analog tuner function on top of the digital services 
provided. 

2 5 These circuits in block 300 function to interface the gateway to one or more 

broadband digital data delivery mediums for downstream only or bidirectional digital data 
communication and to the wireless remote. All combinations will include at least one 
transceiver so that upstream commands from a wireless remote can be sent. 

The receivers/modems are interfaced to a router 302 by a section of circuitry 304 

3 0 which includes an MPEG transport demultiplexer, a video decoder, an MPEG encoder, a 

conditional access decryption circuit and a rate shaping circuit. The rate shaping circuit 
will be present in all species to change the data rate of data travelling in both directions 
(headend to peripheral and peripheral to headend) to match the available bandwidth. 
However, the other circuits in block 304 will be controlled to only be used where necessary 
3 5 because of the type of data or signal received by block 300 or the type of data or signal to be 
transmitted to the headed by block 300. For example, the MPEG transport demultiplexer 
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will only be used when the received data includes an MPEG transport stream containing more 
than one PID to separate out the MPEG packets having different PIDs and group them together 
in the proper order. Likewise, the A/D converter and video decoder, MPEG encoder and IP 
packetization circuit 306 will be used when an analog video broadcast signal is received. 
5 Such signals need to be digitized, converted to YUV format data, MPEG compressed and 

packeted into an IP packet for transmission over the LAISf. The conditional access circuit will 
be used only when the received data is a pay-per-view data or is encrypted such that only 
paid subscribers can use the data and functions to do the necessary decryption and/or 
conditional access gating. Basically, whatever processing Is needed prior to IP packetization 
1 0 on the signals output from whatever transceiver in the transceiver section 300 that 
received the signal or data is performed by the appropriate circuitry in block 304. 

The IP packetization circuit 306 received compressed video data and other auxiliary 
and IData from the headend which needs encapsulation into IP packets and encapsulates the 
data into IP packets addressed to process in the settop decoder of the TV or the wireless 

1 5 remote control where the video program is to be viewed or some other peripheral that needs 

iData. The IP packetization process performs the reverse process for data being transmitted 
to the headend by stripping off the IP packet headers in some embodiments and leaving them 
on in other embodiments. The process to which the data is addressed in the IP packet header 
is the MPEG decompression process where the data is decompressed prior to conversion to a 

2 0 format which can be displayed. 

IP packetization circuit 306 also serves the function of the IP wrapper circuit 276 
of Figure 6 to wrap the IP packets in LAN packets, preferably Ethernet LAN packets, having 
a LAN station address that is mapped to the PID of the video program encoded in the packets. 
This way router/packet switch 302 can be an inexpensive LAN packet switch in the 

2 5 preferred embodiment. In such embodiments, after the router has sent the packets to one of 

the LAN NIC interfaces 310 through 318, if the LAN headers are not of the type used in the 
protocol implemented by the LAN NIC, the NIC strips off the LAN headers and puts new LAN 
headers on which are addressed to the peripheral that ordered the service. Host 308 will 
communicate with each NIC and give it mapping information to map the addressing 

3 0 information in the LAN packet headers coming out of the router into the LAN address space of 

the NIC in question. 

Home PNA LAN NIC 310 includes all the software and hardware to manage and 
communicate over a PNA LAN. 

NIC 312 contains all the hardware and software to manage and communicate over an 
35 IEEE 802.3 or 802.5 Ethernet protocol LAN implemented on Category 3, 4 or 5 unshielded 
twisted pair wiring or over shielded twisted pair or coaxial cable. 
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A wireless LAN is implemented by the liardware and software of NIC 314 to provide 
pliysical layer and media access control (IVIAC) protocols according to the IEEE 802.11 
standard for longer distance wireless links than Blue Tooth l-ANs can provide. NIC 316 
implements the Blue Tooth LAN physical and media access control hardware and software 
5 protocols. NIC 318 implements the hardware and software to manage and communicate over 
power line and/or telephone line LANs and provides the physical layer and media access 
control circuitry and protocols to do so. 

LAN NIC 31 9 implements the hardware and software to manage and communicate over 
frequency division multiplexed upstream and downstream local area networic channels on 
1 0 existing cable television coaxial cable already in existence in a customer premises. NIC 319 
provides the circuitry to receive LAN paci<ets from router 302 and strip off the LAN pacl<et 
headers and put on LAN packet headers suitable for the CATV coax l-AN and transmit them on 
the proper outbound frequency channel. NIC 319 also provides the circuitry to receive LAN 
packets from the inbound frequency channel, strip off the LAN headers and repacketize the 

1 5 encapsulated IP packets into LAN packets of a type router 302 understands and send them to 

router 302. 

These NICs 310 to 319 may be coupled to the gateway via modular connections. This 
structure Is referred to in the claims as "modularly connected". 

This protocol translation function of stripping off LAN headers of packets coming 
20 from the router and repacketizing into different LAN packets understood by the LAN NIC 
protocols and vice versa, and transmitting and receiving according to the appropriate 
protocols on whatever type LAN is connected to the NIC happens in all the NICs 310 through 
319. An additional function and advantage of packet switch/router 302 is to allow 
peripherals on any one of the LANs coupled to NICs 310 through 319 to communicate with 

2 5 each other through the router 302 and the individual NICs acting as bridges between 

protocols. Thus, smart appliances like refrigerators, microwaves, heating and air 
conditioning units coupled to a power line LAN can be controlled from a personal computer on 
a different LAN such as an 802.3 LAN through router 302 and NIC 318 and NiC 312 or 
through a wireless remote control. In embodiments where there is only one LAN with a 

3 0 shared coaxial cable medium with splitters to split off drop lines to various peripherals, the 

peripherals can still communicate with each other through the splitter's inherent leakage 
from one line to another. 

However, in alternative embodiments, router/packet switch 302 can be an IP packet 
router and packetization of the IP packets into LAN packets occurs at the appropriate NIC to 
3 5 which the IP packets are routed. The various prior art LAN technologies, topologies and 
protocols that can be used are not limited to the examples described here. Additional 
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examples and more detail about existing LAN technologies, routers, packet switching, media 
access control, internetworking, video communications, digital TV, compression and 
bandwidth, MPEG, WAN video networks, congestion management and latency, ATM protocols 
over HFC or pure fiber WANs, LAN-based video networks, gateways, satellite, DSL and cable 
5 modems can be found in Horak and Miller, Communications Systems and Networl<s: Voice, 
Data and Broadband Teclinologies, ISBN 1-55851-485-6 (M&T Books 1997) Foster City, 
Ca., which is hereby incorporated by reference. 

The IP packetization circuit determines which IP destination address to use in 
constructing the IP packets via data received from the host microprocessor 308. When the 
1 0 original request for the program was received by one of the LAN NICs 310, 312, 314, 316 
or 318, it has the l-AN packet header stripped off by the NIC and the IP packet containing the 
request is sent to router 302. The router 302 sends It to the host microprocessor 308. The 
host microprocessor 308 determines from the LAN packet source address containing the 
request which peripheral's network adapter/transceiver transmitted the request on the 

1 5 LAN. The IP address of the MPEG decompression process in this network adapter is then 

transmitted by the host 308 to the IP packetization circuit along with the PID of the 
requested program via the router 302. The host 308 then forwards the request to the 
appropriate transceiver in block 300 via router 302 for transmission to the headend. 
Later, a downstream message is received from the headend that gets routed to host 308 and 

2 0 tells the host which logical channel(s) and subchannel(s) the data encoding the requested 

program will be arriving on. The host 308 then sends a command via router 302 to the 
appropriate transceiver/modem in block 300, where necessary, to control it to tune to the 
right logical channel(s) and subchannel(s) to receive the data. In this example, logical 
channel is the frequency of the carrier and logical subchannel is the timeslot, spreading code 

2 5 or PID used to transmit the data of the requested program In this example. Host 308 then 

sends a message via router 302 to the MPEG transport demultiplexer telling which MPEG 
packets to pick out from the received MPEG transport stream. A message is then sent to IP 
packetization circuit 306 via router 302 telling it to which IP address to address the IP 
packets containing the MPEG packets picked out by the MPEG transport demultiplexer. The 

3 0 host then sends a message to router 302 telling it to which NIC to route those IP packets. At 

the NIC, the IP packets are encapsulated into whatever type packet is used in the particular 
protocol implemented by the NIC, and they are transmitted to the proper NIC on the LAN or 
the proper wireless transceiver. The receiving NIC or transceiver then strips off the LAN 
packet header and routes the IP packet to whatever process the IP packet is addressed to, 
3 5 usually an MPEG decompression process in the case of MPEG packets containing data. In the 
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case of MPEG packets containing iP pacl<et data implementing broadband internet access, tine 
outer IP packets are addressed to a browser or e-mail client on a PC somewhere. 

In tlie embodiment of Figure 8, no separate transceiver for tlie wireless remote is 
siiown. This is because the wireless remote may send commands to or receive data from the 
5 gateway via one of the wireless NIC adapters 314 or 316- In alternative embodiments, the 
wireless remote may exchange commands and data with some settop decoder out on one of the 
LANS and then the commands and data are exchanged with the gateway via LAN packets. 

Each of the NICs 310 through 318 uses a different transmission medium and may use 
a different protocol. Some are wireless, some use existing wiring in the home such as power 
1 0 or phone lines and NIC 312 uses custom CAT 5 wiring added to the home. 

A DHCP server 320 assigns IP addresses to clients on the LANs and in the gateway 
when they power up. TIVO video server and bulk storage hard drive 322 implement some or 
all of the TIVO functions previously described. DVD player 324 is a shared DVD player in 
the gateway that allows a DVD to be watched on any TV in the home by encapsulating the raw 

1 5 digital vidoe data from the DVD disk into an IP packet addressed to the settop decoder that 

requested the DVD. The IP packet is then encapsulated by the DVD player into the type of LAN 
packet that the router 302 uses. This l-AN packet will be addressed to the MPEG encoder in 
block 304. The router 302 sends It to the MPEG encoder which strips off the headers and 
compresses the video data. The compressed data is then sent to IP packetlzation circuit 306 

2 0 for IP packetlzation addressed to the requesting settop decoder. The IP packetlzation circuit 

then encapsulates the IP packet into a LAN packet of the type the router 302 switches and 
sends it to the router in embodiments where the router 302 switches LAN packets (no LAN 
packet encapsulation is necessary if router 302 is an IP packet router. The resulting IP 
packets are then routed to the appropriate NIC by router 302 under control of host 308 and 

2 5 are there re-encapsulated in the appropriate LAN packet for the protocol implemented by 

the NIC and transmitted to the requesting settop decoder. 

The router 302 is a conventional LAN packet switch in embodiments where block 
306 is an IP wrapper that wraps IP packets in LAN packets, and is an IP packet router 
where LAN packet encapsulation does not occur in block 306. Router 302 functions to use 

3 0 addressing information in the packet headers and routing tables built from data supplied by 

host 308 as to where everything needs to go to route data to the proper destination. Router 
302 is also coupled to optional display 323 and keyboard/pointing device 325 peripherals 
through suitable interfaces 326 and 328, respectively. The display and keyboard allow the 
gateway to be controlled directly from the keyboard and display as opposed to through a 
3 5 wireless remote transceiver interface 327 and router 302. Wireless remote transceiver 
interface sends and receives wireless commands and data to a wireless infrared or RF remote 
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possibly having a display and does all interfacing needed including LAN packetization to get 
commands and data routed by router 302 to fiost 308, TIVO server 322, the headend or other 
destinations to control the gateway and/or headend to supply the requested services to the 
requested peripherals. 

5 In some embodiments, the gateway's host 308 will have added functionality programs 

stored in memory 324 to provided added capability to the gateway as email, voicemail, PBX 
functions, web server functionality and a shared answering machine. 

An e-mail program 330 provides the capability for email to be sent and received via 
a television set and wireless remote or wireless l<eyboard out on the local area networl<s. 
1 0 The e-maii program controls host 308 to control the router such that LAN packets 

containing IP packets containing requests to retrieve e-mail are routed to host 308 and e- 
mail process 330. The e-mail process then controls host 308 to generate an IP packet 
addressed to the mail server of the internet service provider (ISP) of the customer that 
made the request and sends it to router 302 to send to the appropriate transceiver in block 

1 5 300 or to conventional modem in PSTN interface 332 for transmission to the headend server ' 

coupled to the internet for transmission to the ISP mail server or via the PSTN to the ISP's 
mail server. The ISP mail server then sends back IP packets addressed to the e-mail 
process 330. These packets get routed to host 308 because the e-mail process 330 controls 
the host to set up the routing tables in this way. The e-mail process 330 controls host 308 

2 0 to receive these IP packets containing e-mail either from the server at the headend via one 

of the broadband connections 14A, 14B, 14C, 14D (wireless local loop) or 14E (OC-1 or 
OC-3) or, in some alternative embodiments, via the conventional modem in PSTN interface 
332. The host 308 extracts the e-mail data and encapsulates it in an IP packet addressed to 
an e-mail process in a settop decoder box of one or more of the TVs out on the LANs coupled to 

2 5 the NICs 310 through 318. These IP packets are then encapsulated into LAN packets of the 

type packet switch 302 can route and sent to the switch which routes them to the 
appropriate NIC. The NIC then strips off the LAN header if necessary and replaces it with 
whatever LAN header is used in the protocol implemented by the NIC. In the preferred 
embodiment, packet switch 302 is an Ethernet protocol switch because they are cheap and 

3 0 plentiful. However, if the packets need to be sent over a wireless LAN with its own 

proprietary protocol such as the Blue Tooth protocol, the Ethernet headers need to be 
stripped off and replaced with Blue Tooth LAN packet headers. 

At the settop decoders, the e-mail data is stripped out of the packets and converted to 
an analog NTSC, PAL or SECAM video signal just like auxiliary data that comes with video 
3 5 programs gets converted in the same way. In some embodiments, the analog signal containing 
the e-mail can be superimposed on whatever video program is being watched such as in a 
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scrolling banne above or below the picture or in "picture-in-picture" box that can be 
moved around the screen. 

If the user wishes to reply or send an e-mail, a command is sent from the wireless 
remote or keyboard which gets routed to process 330 which then sends out data for a 
5 message composition screen. This screen gets displayed, and as characters are entered into 
the various fields via the wireless keyboard or remote control, they are displayed on the 
composition screen either by being echoed back from the e-mail process 330 or by a 
wireless remote transceiver process at the settop decoder. When the message is ready to 
send, the user gives a send command by invoking an toon or typing a text command. The data 
1 0 is the message is then encapsulated in an IP packet addressed to the mall server of the 

customer's ISP. This is done either by the e-mail process 330 or by a process in the settop 
decoder depending upon where the wireless remote transceiver is located and the message is 
composed and stored in memory. If that happens at the settop decoder, the IP packets are 
encapsulated into LAN packets addressed to process 330 and sent to the NIC where they get 

1 5 routed to process 330. Host 308 then does the appropriate header stripping and additional 

encapsulation if necessary to get the packets addressed to the appropriate transceiver in 
block 300 or conventional modem in interface 332 for transmission to the mail server. 

In some alternative embodiments, a voicemail and/or PBX application 334 
(hereafter referred to as the PBX application) will control host 308 to allow the gateway to 

2 0 double as a PBX with voicemail recording capability and implement voice-over-IP services 

for telephones coupled via LAN adapters to one or more LANs coupled to the gateway. In these 
embodiments, the PBX application controls the host 308 to monitor incoming calls from the 
PSTN via PSTN interface 332 and incoming calls from voice-over-IP channels and to 
provide traditional PBX functionality including provision of voicemail. Some of this 

2 5 traditional PBX functionality is to set up conference calls, to transfer calls to different 

extensions, to multiplex multiple incoming simultaneous calls on different voice-over-IP 
channels to the appropriate extension phones coupled to the gateway via a LAN, to multiplex 
simultaneousl outgoing calls from different extensions onto multiple voice-over-IP 
channels on one or more of the broadband transmission mediums coupled to block 300, to 

3 0 park an Incoming call on a busy extension, to put a caller on hold, and do any other 

traditional PBX only functions. PSTN interface circuits to interface personal computers to 
the PSTN to do the PSTN signalling protocol, generate call progress tones, dial numbers, 
digitize incoming analog voice signals for processing by the computer, convert digitized 
voice to analog signals, etc. are commercially available from Dialogic and other sources. 
3 5 Interface 332 and PBX application 334 represent the hardware and software of these prior 
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art systems as modified to worl< in tlie gateway environment witin LANs coupling the 
individual telephones to the gateway. 

The modifications needed to the prior art hardware and software are as follows. Host 
308 must build routing data in the routing tables such that call status pacl<ets coming from 
5 PSTN interface 332 are routed to host 308, and signalling packets generated in host 308 are 
routed to interface 332 and call progress tone packets such as ring signals, busy signals, 
etc. generated by host 308 are routed to the appropriate NIC for sending to the proper 
telephone adapter. For example, suppose an incoming ring signal is detected by interface 
332. A signal packet indicating a ring will be routed to host 308. Host 308 generates an 
1 0 "answer packef telling the interface 332 to go off-hook and generates and sends message 
packets to play a greeting message to interface 332. The interface goes off hook, converts 
the message data to analog voice signals and couples these analog signal on the PSTN lines. 
Typically, the greeting would say something like, 'Thank for calling the Smith residence. If 
you would like to talk to Sonia, dial ext 10. If you would like to talk to .... If you would like 

1 5 to leave a voicemail message, dial ext 34." The incoming dial tones for the chosen extension 

are detected by interface 332, packetized and routed to host 308. Alternatively, the tones 
are digitized and sent to host 308 for recognition. The host 308 then responds under control 
of the PBX function to carry out the request. If the caller wants to speak to SonIa, the host 
generates a "ring control" IP packet addressed to Sonia's telephone adapter and encapsulates 

2 0 it in a LAN packet addressed to Sonia's telephone adapter or the NIC to which it is coupled by 

a LAN. Router 302 routes the packet to the appropriate NIC, and it is transmitted on the LAN 
or repacketized and transmitted on the 1-AN to Sonia's telephone adapter which converts it to 
a ring signal and rings Sonia's phone. A timer or ring counter is started by the host for 
purposes of diverting the caller to voicemail if Sonia does not answer. 

2 5 Sonia's telephone adapter detects when Sonla answers her phone, and sends back a 

packet indicating the phone was answered. If Sonia does answer her phone, and speaks, the 
telephone adapter digitizes her voice, packetizes the data in IP packets addressed to host 308 
and packetizes the IP packets In LAN packets and sends them on the LAN. The NIC receives the 
packets and repacketizes them if necessary into LAN packets the router 302 uses addressed 

3 0 to host 308 and sends them to the router for routing to the host. In alternative 

embodiments, these packets may be repacketized by the NIC under control of the host 308 
into LAN packets addressed to interface 332 and routed directly to the interface. If they go to 
the host, the host repacketizes them addressed to interface 332 and sends them to the router 
for transfer to the PSTN Interface 332. The interface does D/A conversion to convert the 
3 5 data of Sonia's voice to analog audio and plays the audio out on the PSTN pair. When the call 
is finished and one or the other conversant hangs up, this fact is detected by interface 332 or 
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Sonia's telephone adapter and a control packet is sent to host 308 which sends a control 
packet to interface 332 causing it to go on-hook and sends any necessary call progress tone 
packet to Sonia's telephone adapter to, for example, cause it to play a dial tone if the caller 
was first to hang up. 

5 If Sonia's phone was not answered, and timeout occurs without receiving a "phone 

was answered" packet, the host 308 generates and sends to interface 332, packets that play 
Sonia's prerecorded voicemail greeting. The interface 332 converts them to analog audio and 
plays them on the PSTN pair. The greeting includes a beep tone to signal when to start 
leaving a message. When the caller speaks her message, the sound is digitized and packetized 
1 0 and addressed to the voicemail process In the PBX process 334. The voicemail process 
creates a file in a directory structure on hard disk 338 or the TIVO server hard drive 322 
and stores the voicemail data in the file. The host 308 then sends a control packet to Sonia's 
telephone adapter to cause it to light a message waiting light or other give a message waiting 
indication. 

1 5 Outgoing calls work as follows. When Sonia picks up her phone, her adapter sends a 

control packet to the host over the LAN saying she has gone off-hook. Host sends back call 
progress tone packets over the LAN to cause the adapter to play a dial tone. Sonia dials a 
number. The adapter either recognizes the UTMF tones or digitizes them and sends them to 
the host for recognition. Either way, the host receives data from which it can figure out the 

2 0 number called. The host reacts by sending control packets to interface 332 telling it to go 

off hook and dial a certain number. The interface goes off hook, and then a DTMF generator in 
the interface 332 generates the DTMF tones of the number dialed. Call progress tones such 
as ringing tones from the central office are recognized and control packets are sent to host 
308 or simply digitized and sent to host 308 for recognition. Host 308 sends the same call 

2 5 progress tones in LAN packets to Sonia's telephone adapter over the LAN. When the called 

party picks up and speaks, the voice is digitized, packetized and routed to host 308 which 
repacketizes it into IP packets and LAN packets addressed to Sonia's telephone adapter and 
sends them to the router. The router routs them to the proper NIC and they then may get 
repacketized into the LAN packets for the particular LAN protocol In use and then they are 

3 0 sent on the LAN. The reverse process happens for packets containing Sonia's digitized voice 

replies. 

This functionality just described for PBX application 334 is referred to in the 
claims as voicemail and PBX functionality. In some embodiments, the phones may be coupled 
to the gateway by dedicated lines In which case, host 308 controls an interface like 332 for 
3 5 each tip and ring pair coupled to a phone in the household, and the software is modified to not 
send and receive digitized voice and control and call progress packets to telephone adapters 
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over a LAN but sends them directly to the appropriate interface coupled to the tip and ring 
pair coupled to the appropriate phone. 

In some alternative embodiments, a web server application 340 controls host 
computer 308 to serve web pages to browsers on the internet. This is done via a suitable 
5 interface 332 to a T1 , partial T1 or ADSL channel to a router or switch coupled to the 
internet at a PSTN central office or via a dedicated T1 line through the central office to an 
Internet Service Provider (ISP) to provide an always on channel to a router/switch on the 
internet at the ISP. In alternative embodiments, the always on connection to the Internet is 
provided via a cable modem in block 300 and an HFC channel to a router or switch coupled to 
1 0 the internet at the cable plant headend. In still other embodiments, connectivity to the 

internet may be made through a Starband transceiver In block 300 and a satellite uplink and 
a satellite downlink to router or switch coupled to the internet at the Starband server farm. 
Wireless local loop connections to the internet may also be used in some embodiments. 

Web browsers can visit the URL of web server 340 and request one or more web 

1 5 pages. These web pages are packetized In IP packets addressed to the web browser that 

requested them by host 308 and are then packetized in LAN packets of the type switch 302 
understands addressed to T1 interface 332, all under control of web server 340. The LAN 
packets are then sent to router 302 which sends them to T1 interface 332 which strips off 
the LAN packet headers and transmits them to the router on the internet on T1 timeslots. 

2 0 The router on the internet gets them to the browser that requested them. Further requests 

from the browser are sent back to T1 interface 332 as IP packets that get routed by router 
302 to host 308 and web server process 340. 

The web server application is an HTTP server program such as HTTPD running on a 
Unix operating system, Microsoft's Internet Information Server or Netscape's Enterprise 

2 5 Server running under a Windows operating system. 

In some embodiments, the host 308 is further programmed by an answering machine 
program 342 to provide a shared answering machine to record messages for all members of 
the household for Incoming conventional PSTN telephone calls arriving via PSTN interface 
332 or via voice-over-IP packets arriving from the headend via cable modem, satellite 

3 0 transceiver, etc. in block 300. The answering machine program controls host 308 in a 

manner identical to that previously described for the voicemall functionality of the PBX 
program 334, but It does not provide the PBX functionality of PBX program 334 to set up 
conference calls, transfer calls to different extensions, multiplex multiple simultaneous 
calls onto different voice-over-IP channels on one of the broadband transmission mediums 
3 5 coupled to block 300, park an incoming call on a busy extension, put a caller on hold, and 
other traditional PBX only functions. 
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Referring to Figure 9, there is sfiown a blocl< diagram of a wireless remote control 
implemented on a personal digital assistant (PDA) having wireless capabilities. The remote 
control of Figure 9 can do all regular PDA functions it is programmed to do such as calendar 
and appointments, word processing, database and address book functions. However, in 
5 addition, it has a wireless RF transceiver module 380 that plugs into the PDA's PCMCIA or 
Handspring Visor Springboard slot by which commands and data can be exchanged with the 
transceiver of a home gateway or some settop decoder with a transceiver on a LAN coupled to 
the gateway. In alternative embodiments, module 380 is a wireless LAN NIC that couples the 
remote to the gateway through a wireless LAN or hardwired LAN having a peripheral coupled 
1 0 thereto which communicates with the NIC 380. The PDA is programmed with various 
programs which implement various ones of the following functions: menu display, 
transmission of upstream requests, receiving and decompressing an MPEG compressed video 
stream and converting the data to a format suitable for display on the PDA display, TCP/IP 
processing of IP packets, web browsing, smart appliance control, TIVO function control for 

1 5 digital video recording and video special effect control of TIVO functions implemented by the 

home gateway or headend, IP telephony, MP3 player and cellular telephony. 

The PDA remote 399 is comprised of a host processor coupled by conventional 
circuitry to an LCD or TFT or any other conventional computer display 402 and to a 
keyboard, pointing device or other user input device on the PDA. The host 400 is also 

2 0 coupled to audio input and output circuits 406 to allow playing of MP3 files and receiving 

audio inputs such as voice commands to control TIVO functions, change channels, order 
movies, play games etc. Voice recognition software of a conventional variety may be used if 
voice commands are to be given. PCMCIA or springboard modular wireless transceiver or 
wireless LAN NIC (hereafter just PC card) 380 provides the connectivity to the gateway 

2 5 either directly or through a wireless or other LAN coupled to the gateway to send and receive 

commands and data. 

Memory 408 may be volatile or nonvolatile EEPROM and usually has some of each. 
The memory has a reserved frame buffer 410 and working address space 412 which 
includes both memory and I/O space for the PC card. In some embodiments, the PC card 

3 0 includes auxiliary expansion memory which may be accessed simultaneously with the other 

circuitry on the PC card as is known in the art. An operating system 41 5 is shown as stored 
in working memory. Memory 408 also includes one or more programs that drive menu 
displays on display 402, but these are usually part of OS 415 or any of the other application 
programs. 

3 5 One or more programs 416 control host 400 and display 402 to display menus from 

which services provided by the headend may be ordered or invoked by receiving input from 
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keyboard/input device 404. This causes liost 400 to generate an IP packet using TCP/IP 
stack programs 418 requesting tfie service and sends it PC card 380 for transmission to the 
gateway. These upstream request packets can include such requests as ordering a video on 
demand selection, changing a channel for broadcasts, ordering a preview of another channel 
5 or VOD selection to be sent to the PDA remote 399 for viewing on display 402 while 

something else is watched on a TV connected directly or indirectly to the gateway, etc. One or 
more MPEG decompression programs 420 control host 400 to receive MPEG compressed 
streaming video of previews, game video, etc. to be displayed on remote display 402 and 
decompressed the video back to its uncompressed state. Program(s) 420 then control host 
1 0 400 to convert the video to a state In which it can be viewed on display 402 and stores each 
frame of data in frame buffer 410. 

One or more programs implementing a web browser control host 400 to send 
upstream IP request packets via PC card 380 to the gateway. The gateway routes the packets 
to the web server in the gateway, if implemented, or to a web server connected to the 

1 5 internet through a conventional modem or a broadband internet channel on the broadband 

medium(s) 14. These packets allow the user to use the PDA remote to browse the internet 
in wireless fashion and to receive IP packets containing web page data and e-mail and 
attachments. The program(s) 422 control host 400 to strip out the data and convert it to a 
format for display on display 402. 

2 0 One or more programs 424 allows the user to use the PDA remote to, in a wireless 

fashion, control various smart appliances coupled to the gateway through the LAN. Thus, the 
user can turn on a coffee machine or microwave, lower or raise her thermostat, turn an 
oven on or off, etc. while watching TV in another room. 

One or more programs 426 control the host 400 to receive TIVO menu packets and 

2 5 display the menus, and receive user input from the keyboard or pointing device to make 

selections of TIVO functions to be implemented by the gateway or headend etc. 

One or more programs 428 control host 400 to implement IP telephony to allow the 
user to make free long distance calls in a wireless fashion. Program(s) 428 control host 
400 to received digitized voice data from audio I/O circuits 406 and to receive dialing 

3 0 instructions from the keyboard/input device 404 (a telephone keypad may be displayed on 

display 402 and numbers picked by pointing device). IP packets are then sent back and 
forth to the gateway for dialing, call progress sounds and incoming and outgoing digitized 
voice. The gateway routes these packets via a broadband medium to a server on the internet 
which routes them to a server at the other end which interfaces the internet to a 
3 5 conventional phone via the local loop or to another IP telephony process for conversion to 
sounds the other conversant can hear and do all the other things necessary to complete the 



40 



wo 03/005713 PCT/US02/20841 
call. The IP telephony programs substitute the packet switching of the internet for the 
traditional switched circuit dedicated connections of the PSTN. 

One or more programs 430 control host 400 to order MP3 music files from an MP3 
server in the gateway, decode the files into digital data that can be piayed by the audio I/O 
5 circuits 406 and send the decoded data to the audio I/O circuits 406. 

One or more programs 432 control host 400 to use audio I/O circuits 406 to convert 
the PDA remote into a cellular telephone. This worl<s the same way as the IP telephony, 
except the digitized voice, status and control traffic, call progress tone data, dialing 
instructions, etc. are encapsulated in IP packets and then encapsulated in LAN packets the 
1 0 router in the gateway understands. These packets are then transmitted directly to the 
gateway or to a wireless LAN NIC for transfer to the gateway with appropriate LAN packet 
encapsulation/translation for the intervening protocols between the PDA and the router in 
the gateway. The router in the gateway then routes them to a cellular transceiver in the 
gateway for coupling to the cellular network. In alternative embodiments, the IP packets 

1 5 containing cellular data may be sent over a broadband medium to the headend where it is 

routed to a cellular transceiver coupled to the cellular network. This is especially effective 
where cellular coverage does not reach a customer's home but does reach the headend. 

One or more programs 434 control the host to do conventional PDA functions such as 
calendar, address book, word processing and database functions. Another program which 

2 0 may be present as symbolized by block 434 controls said host 400 to carry out a discovery 

process to determine what servers are present in the gateway and/or headend and what their 
IP addresses are. 

Although the invention has been disclosed in terms of the preferred and alternative 
embodiments disclosed herein, those skilled in the art will appreciate possible alternative 
2 5 embodiments and other modifications to the teachings disclosed herein which do not depart 
from the. spirit and scope of the invention. All such alternative embodiments and other 
modifications are intended to be included within the scope of the claims appended hereto. 
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What is claimed is: 



1 1 . A headend cherrypicker that Implements TIVO functions, comprising: 

2 a packet switch; 

3 a plurality of video servers and satellite feed servers coupled to supply 

4 MPEG packets encoding a plurality of video programs; 

5 a hard disk array storing MPEG packet video data encoding TlVO-like 

6 function menus and for storing MPEG packet video data to record programs for 

7 which a customer has requested recording; 

8 an IP wrapper circuit functioning to receive said MPEG packets from said 

9 plurality of video servers and said hard disk array and encapsulate them in IP 

1 0 multicast packets and encapsulate the IP multicast packets in local area network 

1 1 (LAN) packets having station addresses that correspond to said program identifier 

1 2 data and supplying said l-AN packets to said switch; 

13 a cable modem termination system and cable modem for coupling to a hybrid 

1 4 fiber coaxial cable transmission medium (HFC) for transmitting IData and command 

1 5 and control data downstream to customers and for receiving commands from each 

1 6 customer to order video programs including recorded programs or TIVO menus and 

17 to control TIVO functions performed for that customer; 

1 8 one or more network cherrypickers and transmitter combinations coupled to 

1 9 said switch, each said transmitter coupled to said HFC for transmitting said 

2 0 requested programs, recorded programs or TIVO menus to one or more customers; 

2 1 a system control computer programmed to exchange data with said switch and 

2 2 control routing by said switch to receive upstream requests for video programs and 

2 3 TIVO function commands and assign one or more logical channels on said HFC to each 

2 4 requested video program, recorded program or menu and to route data encoding 

2 5 requested video programs from one or more of said video servers and recorded 

2 6 programs or TIVO function menus from said hard disk array to one or more network 

2 7 cherrypicker and transmitter combination for transmission to the customer that 

2 8 requested the data, and to route a downstream message to said cable modem to said 

2 9 customer telling the customer on which logical channel the requested data will be 

3 0 arriving and for routing data encoding video programs to be recorded to said hard 
3 1 disk array. 
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1 2. The apparatus of claim 1 further comprising at least one web server coupled to 

2 said switch through an IP wrapper circuit and which outputs to said IP wrapper circuit IP 

3 format packets encapsulated in MPEG packets having a PID which identifies the source of 

4 the IData, and wherein said system control computer is programmed to control said switch 

5 to use said cable modem termination system and said cable modem to provide broadband 

6 internet access to customers. 

1 3. The apparatus of claim 1 further comprising one or more game servers which 

2 output game data in MPEG packets to an IP wrapper circuit coupled to said switch, and 

3 wherein said system control computer controls said switch to send and receive game data 

4 packets to and from customers who are, at their premises, playing games resident on said 

5 game server. 

1 4. The apparatus of claim 1 further comprising one or more EMM servers, 

2 electronic program guide servers, Tmaii servers or data carousel servers for sending and 

3 receiving MPEG packets encapsulating IData to one or more customers through one or more 

4 IP wrapper circuits and said packet switch and one or more of said cherrypicker and 

5 transmitter combinations, and wherein said control computer is programmed to control 

6 said switch to facilitate said said exchanges of data with said customers. 

1 5. The apparatus of claim 1 further comprising one or more transcoder servers 

2 coupled to said packet switch for altering the data rate of incoming packets in accordance 

3 with rate shaping commands and for outputting to said switch rate shaped data, and wherein 

4 said system control computer is programmed to route data encoding requested video 

5 programs, TIVO function menus, or IData to one or more of said transcoder servers and to 

6 control said one or more transcoder servers with rate shaping commands to alter the data 

7 rate of said data to a data rate that matches the available bandwidth to transmit said data to a 

8 customer, and to control said switch to route the rate shaped data to one or more network 

9 cherrypicker and transmitter combinations for transmission to the customer that 
1 0 requested the data on the assigned logical channel. 



1 6. A headend cherrypicker that implements TIVO functions, comprising: 

2 a packet switch; 

3 a plurality of video servers and satellite feed servers coupled to supply 

4 MPEG packets encoding a plurality of video programs; 
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5 a plurality of personal video recorder servers, each for implementing TIVO 

6 functions for one or more customers by outputting MPEG packets encoding TIVO 

7 function menus and prerecorded programs and for receiving and recording MPEG 

8 packets encoding video programs to be recorded for eacin customer; 

9 an IP wrapper circuit functioning to receive said MPEG packets from said 

1 0 plurality of video servers and said personal vidoe recorder servers and encapsulate 

1 1 them in IP multicast packets and encapsulate the IP multicast packets in local area 

1 2 network (LAN) packets having station addresses that correspond to said program 

1 3 identifier data and supplying said l-AN packets to said switch; 

14 a cable modem termination system and cable modem for coupling to a hybrid 

1 5 fiber coaxial cable transmission medium (HFC) or one or more DSL modems for 

1 6 coupling to one or more DSL lines or a satellite uplink and downlink modem for 

1 7 coupling to a satellite dish, said modem for transmitting IData and command and 

1 8 control data downstream to customers and for receiving commands from each 

1 9 customer to order video programs including recorded programs or TIVO menus and 

2 0 to control TIVO functions performed by said one or more personal video recorder 
2 1 servers for that customer, said HFC, one or more DSL lines or satellite dish 

22 hereafter referred to as the transmission medium; 

2 3 one or more network cherrypicker and transmitter combinations coupled to 

2 4 said switch, each said transmitter coupled to said transmission medium for 

2 5 transmitting said requested programs, recorded programs or TIVO menus to one or 

2 6 more customers; 

2 7 one or more transcoder servers coupled to said packet switch for altering the 

2 8 data rate of packets sent to said transcoder servers to a different data rate in 

2 9 accordance with rate shaping commands; 

3 0 a system control computer programmed to exchange data with said switch and 
3 1 control routing by said switch to receive upstream requests for video programs and 
3 2 TIVO function commands and assign one or more logical channels on said 

3 3 transmission medium to each requested video program, recorded program or menu 

3 4 and to route data encoding requested video programs from one or more of said video 

3 5 servers and recorded programs or TIVO function menus from said one or more 

3 6 personal video recorder servers to one or more of said transcoder servers and to 

3 7 control said one or more transcoder servers with rate shaping commands to alter 

3 8 the data rate of said data to a data rate that matches the available bandwidth to 

3 9 transmit said data to a customer, and to control said switch to route the rate shaped 

4 0 data to one or more network cherrypicker and transmitter combinations for 
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4 1 transmission to the customer that requested the data, and to route a downstream 

4 2 message to said cable modem to said customer telling the customer on which logical 

4 3 channel the requested data will be arriving and for routing data encoding video 

4 4 programs to be recorded to said one or more personal video recorder servers. 

1 7. The apparatus of claim 6 further comprising at least one web server coupled to 



2 said switch through an IP wrapper circuit and which outputs to said IP wrapper circuit IP 

3 format packets encapsulated in 1\/IPEG packets having a PID which identifies the source of 

4 the IData, and wherein said system control computer is progranrimed to control said switch 

5 to use said cable modem termination system and said cable modem to provide broadband 

6 internet access to customers. 

1 8. The apparatus of claim 6 further comprising one or more game servers which 

2 output game data in MPEG packets to an IP wrapper circuit coupled to said switch, and 

3 wherein said system control computer controls said switch to send and receive game data 

4 packets to and from customers who are, at their premises, playing games resident on said 

5 game server. 

1 9. The apparatus of claim 6 further comprising one or more EMM servers, 

2 electronic program guide servers, Tmail servers or data carousel servers for sending and 

3 receiving MPEG packets encapsulating iData to one or more customers through one or more 

4 IP wrapper circuits and said packet switch and one or more of said cherrypicker and 

5 transmitter combinations, and wherein said control computer is programmed to control 

6 said switch to facilitate said said exchanges of data with said customers. 
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